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INTRODUCTION 



NATIONAL 304 SYSTEM 

The National 304 Systeiri is a moderate size electronic data processor 
for general business use. It incorporates naany new design concepts which 
result in performance capabilities comparable to those of a large scale 
system. Each of the many features were designed to provide maximum 
versatility for handling of busines's data. The National 304 System offers 
the advantages of electronic data processing to many organizations that 
have not yet found it economically feasible. 

The comiplete system consists of the central computer or data proc- 
essor, magnetic tape storage files, and various auxiliary input-output 
units as shown in Figure I-l. 

Control Console : The control console provides the power control, in- 
dicating lights, and operating switches for all units in the system which 
are connected directly to the processor. The operator^'s control panel 
contains lighted display for processor operation, and for the operation of 
auxiliary equipment. The control console is equipped with a paper tape 
operated electric typewriter which provides direct communication with 
the processor memory. The control typewriter permits the operator to 
manually fill or interrogate the memory. 

Central Processor : The NCR Model 304 Data Processor is the basic unit 
in the system. This machine is a general-purpose, electronic digital 
computer. Automatic operation is under control of an internally stored 
program. The high-speed main memory is of magnetic core construction, 
having a capacity of 1000 or 2000 ten-character words with an additional 
2000 words available on order. Transistors and rnagnetic cores are em- 
ployed throughout as logical elements because of their low power require- 
ments, low heat generation, high reliability and compact size. 
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All units in the systena are capable of handling alphabetic, numeric, 
and editorial information. The pro ces sort's command structure provides 
fast, efficient performance of arithmetic tasks, as well as all types of data 
processing operations. For those operations which are common to every 
business data problem, such as sorting, summarizing, editing etc. , the 
processor contains special purpose commands. Each of these special 
purpose commands is equivalent to a complete subroutine. This feature 
provides maximunn processing efficiency with minimum programming re- 
quired. Internal self-checking is provided to insure the accuracy of inter- 
nal operations and information transfer between the processor and the 
peripheral equipment. 

Paper Tape Reader; The NCR Model 360 Photoelectric Tape Reader pro- 
vides high-speed paper tape input to the system. The reader is capable of 
reading three different punched paper tape codes at the operators selection. 
These codes may be punched in 5, 6, 7 or 8 channel tape. The reader is 
primarily designed for fast efficient processing of paper tape generated 
by National cash registers, accounting machines, and adding machines 
as a by-product of their original recording function. However, this flex- 
ibility insures coraipatibility with all types of paper tape producing equip- 
ment. Self-checking features are included to insure the accuracy of read- 
ing,and also punching, when checkable codes are being read. Paper tape 
reading speed is at the rate of 1000 characters per second. 

Punched Card Reader : The NCR Model 380 Photoelectric Card Reader 
provides high-speed punched card input to the system. The reader is 
capable of handling 80 column IBM punched cards. Provision is made for 
reading a portion or the full 80 columns of each card. Card columns may 
contain either numeric, alphabetic, or symbolic punching. Self-checking 
is provided by dual reading stations. Card reading is performed at the 
rate of SQJO cards per minute. 
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Magnetic Tape File : The NCR Model 330 Magnetic Tape File provides 
both large capacity auxiliary storage and high-speed input-output t^ the 
system. Data is stored on tape in the form of records, which may be of 
variable length. Each 2400 foot reel of tape stores approximately 
4, 300,000 characters of information. A minimum file consists of one 
controller unit with up to eight tapes under its control. As many as eight 
controller units can be employed in a single system. Information is re- 
corded on tape at 150 characters per inch, without gaps between records. 
Read- Write speed is at 100 inches per second, with an acceleration time 
of 5 milliseconds. Thus, the information transfer rate for magnetic tape 
is 15,000 characters per second. 

Many unique capabilities are provided for efficient miagnetic tape 
processing. In addition to the normal functions of reading and writing, the 
magnetic tape equipment has the ability to perform independent searching 
and copying from one tape to another. These independent operations are 
initiated by the processor, but do not require processor supervision. 
During all file "updating" operations, the processor handles only active 
records. Inactive records bypass the processor, and are automatically 
copied to a new tape. This method of processing creates a new updated 
tape containing both the active and inactive records, complete in their 
original sequence. Since records may be of variable length, this system 
provides for fully expandable files. Information is completely Checked 
during all reading and writing operations. Infornaation being written on 
tape is automatically read back and checked to insure complete accuracy 
of tape records without further processing. 

Line Printer ; The NCR Model 340 Line Printer produces printed output, 
either directly from the processor memoVy, or froixi miagnetic tape. The 
printer is capable of printing 120 characters per line at the rate of 600 lines 
per minute. Any one of fifty-six different characters may be printed in each 
of the 120 printing positions. The printer contains internal self-checking 
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features to insure the accuracy of printed information. Multiple copies 
may Ije produced efficiently through the use of NCR carbonless paper, or 
standard carbon interleaved forms. 

Because of its self-contained magnetic core buffer, the printer is 
capable of performing all printing and paper handling functions independent 
of the processor. This permits the processor to be computing simultane- 
ously with printing. This buffer also permits "off-line" printing from 
magnetic tape through the use of a Model 322 Printer- Converter. All 
paper spacing functions where no printing is required are performed at the 
rate of 72 lines per second. 

Printe r- Conve rte r ; The NCR Model 322 Printer -Converter permits off- 
line printing from magnetic tape. This converter has the ability to select 
individual records for printing under control of the operator. Inclusion of 
this unit in a minimum sized system permits all printing and associated 
changing of forms to be completely independent of processor operation. 

Multi- Purpose Converter ; The NCR Model 320 Multi-Purpose Converter 
provides the ability to rapidly transcribe all forms of input data to magnetic 
tape, and to transcribe from magnetic tape to all types of output equipment. 
Inclusion of this unit in a system permits all input-output functions to be 
time shared with processor operation, thus producing a complete "off-line" 
data processing systemi. Off-line operation creates a substantial increase 
in the performance capabilities of the system. Since the processor 
communicates only with inagnetic tape in an off-line systexn, tiraie spent 
on input-output functions is reduced by a factor of fifteen. 

Paper Tape Punch; The NCR Model 370 Paper Tape Punch provides punched 
paper tape output for the system. Two different hole codes may be pro- 
duced in punched paper tape at the operators selection. One of these codes 
is the processor code and the other code optional. Paper tape output punched 
in processor code may be printed through tape operated electric typewriters? 
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^nd may be directly input via the Model 360 paper tape reader, or the 
control type'writer. The optional code may be specified to conform with 
leased-line communication equipment being used in an integrated data 
processing system. Self- checking features provide control over punching 
accuracy. Paper tape punching is performed at the rate of 60 characters 
per second. 

Card Punch ; Punched card output is provided from magnetic tape, through 
the converter,to a modified IBM Type 523 Summary Punch. Information 
being punched in cards is read back and checked immediately by the self- 
checking circuitry. A standard plug-board permits full flexibility for 
column arrangements. Card punching is performed at the rate of 100 cards 
per minute. 
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The National 304 System, in common with all 
large-scale Data Processing systems, uses Magnetic Tape 
as its File medium. Information is recorded on Magnetic 
Tape in serial form; that is, successive characters are 
recorded one after another, with each character being 
represented by a row of magnetized spots (called 
"bits") across the width of the tape. Each of these 
spots may hold either positive or negative magnetiza- 
tion, and the pattern of bits in each row defines the 
character recorded in that row. 

The tape is divided along its length into 8 
Channels, or tracks. Six Channels contain the six bits 



which define each character; the 7th Channel contains 
the check-bit, or parity-bit, which is recorded with each 
character, and which functions as one of the self- 
checking features of the Magnetic Tape System; the 8th 
Channel contains control information (Record- 
Markers). 

Throughout the NCR 304 System, information is 
regarded as organized into "Words". A Word is simply 
a grouping of 10 alphanumeric characters, and each 
successive 10 characters on the tape, therefore, consti- 
tute one Word of information. 
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REPRESENTATION OF INFORMATION ON MAGNETIC TAPE 



However, the major organization of information 
on Magnetic Tape is into Records. A Record may con- 
tain any number of Words from 10 to 100, and is 
bounded on the tape by a Beginning-of -Record Mark 
(BRM) and an End-of -Record Mark (ERM). 

It is important to recognize that a Record is de- 
fined by its physical characteristics and not necessarily 



by the information it contains: It is a group of 10 to 
100 Words recorded on Magnetic Tape, bounded by a 
BRM and an ERM. While one record will most often 
contain one File- Item (one Account, for example), 
convenience may suggest that several Items be included 
in a single Record, or that the information pertaining 
to one Item be recorded as several Records. 



CONTROL 
CHARACTERS 



CONTROL 
CHARACTERS 



RECORD-PARITY 
CHARACTER 



INFORMATION 
CHANNELS 



CHECK-BIT CHANNEL 
RECORD-MARKER CHANNEL^ 




llllllllllllllllllll 

III 
ERM IBRM 



H 



lllllllllllllllllllllllllllllll 












lllllllllllllllllllllllllllllll 












llllllllllllllllllllllllillllll 












lllllllllllllllllllllllllllllll 












lllllllllllllllllllllllllllllll 












lllllllllllllllllllllllllllllll 












lllllllllllllllllllllllllllllll 













ERM 



ONE RECORD 



STRUCTURE OF A RECORD ON MAGNETIC TAPE 
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The Record illustrated on the previous page, con- 
sisting of 170 alphanumeric characters, when drawn to 
actual scale, would look like this: 
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File Record in turn to some standard location in 
Memory. 

SAWNG SPACE; 

1) Variable-length Records permit each record to 
be only as long as its information content requires it 
to be. All blank words within the Record have been 
eliminated. 



Since, by the very nature of the medium, the speed 
of reading and recording Magnetic Tape is lower, by 
a substantial factor, than the operating speed of a Data 
Processor, it is of the utmost importance that informa- 
tion transfer rates to and from Magnetic Tape be as 
high as possible. The NCR 304 System has achieved 
extremely high Magnetic Tape speeds, but what is even 
more significant, it has increased the efficiency of the 
recording technique, so that for the first time in any 
Data Processing System, the effective speed of informa- 
tion transfer is almost identical with the nominal speed. 

This efficiency has been accomplished by: 

• Reducing the delays inherent in any Magnetic Tape 
System (Saving Time). 

• Eliminating blank areas in which no information is 
recorded on the tape (Saving Space). Any blank area 
on the tape must be passed over in order to reach 
the information beyond, and therefore, blank spaces 
would also represent lost time within the System, 

• Full Alphanumeric Recording. Since 6 bits (magnetic 
spots) are used to record each character, the stated 
information transfer rate in the NCR 304 System 
applies to alphanumeric characters, and not merely 
to numeric digits. However, digits may be recorded 
in condensed form, in which case the effective in- 
formation transfer rate is increased by 50%. (See 
Item 4 under "Saving Space".) 



SAVING TIME: 

Since Magnetic Tape can be read or recorded 
reliably only when moving at full speed, there must be 
an acceleration delay every time the tape is started. 

In the NCR 304 System, not only has this accelera- 
tion time been reduced to a very small figure, but the 
necessity for frequent stops and starts has been largely 
eliminated. Instead of reading or recording only one 
Record at a time, a single operation will read or record 
up to 99 Records, of either fixed or varying lengths, as 
a single continuous flow of information. All the in- 
formation read or recorded with a single Magnetic 
Tape operation is called a "Gulp" of information. 

The use of Index Registers (described in Chapter 
III) makes it particularly convenient to handle the 
successive Records of a Gulp within the Processor, 
without the time-consuming necessity of moving each 



2) "Father-son" expanding file technique com- 
pletely transcribes the File as a by-product of every 
updating "run". The principal advantages of this 
technique are: 

a) Permits new Records to be inserted, or obsolete 
Records to be deleted, wherever required, and still 
keeps the file "closed up tight" at all times. 

b) Permits the length of any individual Record to be 
expanded or contracted during the transcription, as 
the varying information content of the Record may 
require. 

c) Since "yesterday's fUe" is retained unchanged after 
the updating run which creates "today's file", it is 
always available as a rescue point from which "to- 
day's file" can be re-created in case of damage to 
the Magnetic Tape. 

d) The COPY operation gives simultaneous READ- 
WRITE-COMPUTE over inactive Records in the 
file, and is particularly effective in file posting 
when, typically, a minority of the Records are active 
in any one day. COPY is simple to program, and 
affords convenient, effective time-sharing while pass- 
ing over the inactive Records. 

COPY operates as a continuous flow of information 
from "father" tape to "son"; both tapes move from 
one active Record to the next with no intermediate 
stops, and with no supervision by the Processor. 
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UPDATING AN EXPANDING AND CONTRACTING FILE 
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(SAVING SPACE:) 

3) Partial-Word Operation. In order to perform 
computation within a Data Processor, it is conven- 
tionally necessary to have each information field 
(Account Number, Transaction Code, Unit Price, On- 
Hand Balance, etc.) isolated in a separate Word since 
Processors, in general, can operate only upon complete 
Words. However, most information fields require less 
than 10 characters, and it would be an intolerable waste 
of space on Magnetic Tape to record, for example, a 
7-digit Account Number, a 2-digit Code, a 5-digit 
Quantity, each as a 10-character Word in the File. 
Therefore it is common practice, in using Magnetic 
Tape systems, to combine several information fields into 
a single Word for recording on Magnetic Tape. Such a 
File Record, when ready for recording, might look like 
this: 
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EXAMPLE OF A RECORD IN A PRODUCT MASTER FILE 



When a File Record is read into the Processor, 
these combined fields must be split apart into separate 
Words in order to operate on them; then the fields 
must be recombined so that the updated Record may be 
recorded back on Magnetic Tape. 

In the NCR 304 System, this process of combining 
several information fields into a single Word is fully 
automatic, with no restriction on the number of fields 
within a Word, nor on their placement within a Word. 
Since any Partial-Word field may be directly referred 
to by any operation, the programmer may use this 
combining technique to its fullest extent, yet pay no 
penalty in either programming effort, or Processor 
operating time for: 

• Extracting each information field in order to isolate 
it; 

• Shifting one or both fields in order to align them 
with each other, so the desired operations can be 
performed; 

• Shifting the result in order to align it with the 
desired putaway field; 

• Testing the result to be sure it is not too large to fit 
into the putaway field (overflow test); 

• Inserting the result into the putaway field; 

• Tagging the putaway field with the proper algebraic 
sign. 

The Partial-Word operation of the Processor is 
described in detail in Chapter III. 

4) Condensed Recording of Numeric Information. 
Although 6 bits are required to record one alpha- 
numeric character, 4 bits would be sufficient to record 
one numeric digit. Since a large portion of the informa- 
tion in business files is purely numeric, the use of 6 bits 
for every character would mean that, for this numeric 
information, one-third of the recorded bits (and there- 
fore one^third of the Magnetic Tape) would contain 
no useful mformation, and would therefore, in effect, 
be blank. 

In the NCR 304 System, the programmer is able 
to record numeric information in a condensed, or 
PACKED, form in which only 4 bits are used for each 
digit. Three condensed digits, therefore, occupy only 
as much Magnetic Tape as two alphanumeric characters, 
and can be read or recorded in the same amount of 
time as two alphanumeric characters. 

A single PACK operation will condense any de- 
sired amount of numeric information (with an auto- 
matic alarm if alphabetic information is inadvertently 
included), and a single UNPACK operation will later 
expand the condensed information to its original form, 
so that arithmetic operations can be performed on it. 

However, when updating a File Record, the pro- 
grammer need UNPACK only as much of the Record 
as is subject to arithmetic operations. All comparing 
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and testing operations can be performed on the numeric 
data while it remains in condensed form. 

5) Binary Operations. While the NCR 304 Pro- 
cessor operates in the decimal number system, it also 
offers the programmer a set of extremely flexible 
binary operations, which permit access to the individual 
bits within an information field. The programmer can, 
therefore, achieve a high degree of compactness in 
recording certain types of coded .information in a 
Magnetic Tape File. (See EXTRACT, INSERT, ADD 
BINARY, COMPLEMENT BINARY, TEST BIT, in 
Chapter IV.) 

Thus, for example, a "State" code (including the 
50 States, Puerto Rico, and perhaps the Provinces of 
Canada — in fact, up to 64 different "States") can be 
stored as a single character in each customer's File 
Record; or a calendar date (month, day, year) can be 
stored in three characters in the File Record. In a pay- 
roll file, the presence or absence of each of 30 different 
optional pay-deductions can be stored in 30 bit-posi- 
tions (5 characters) in each employee's File Record. 

6) No Inter-Record Gaps. The ability to read and 
record Magnetic Tape continuously, in Gulps of 
Records, would be of relatively little value if there were 
still a substantial gap (blank space) after every Record 
in the file, to allow for the possibility that any Record 
might be the last one of a Gulp. Conventional record- 
ing techniques require a large enough blank space after 
each Record, so that the tape may be stopped there, and 
still have enough space to come up to full speed again 
before reaching the next Record. 

In the NCR 304 System, there are no gaps between 
records on Magnetic Tape. Therefore, whenever a Gulp 
ends, the tape coasts to a stop with the Magnetic Head 
within the next Record. Special repositioning circuitry 
in the Tape Controller immediately assumes control of 
the Tape Handler, backs up the tape until the BRM- 
ERM is reached, and then stops the tape again, with 
the Magnetic Head now within the last Record of the 
Gulp, ready for a "flying start" at the next Record. 

The Processor is released from the Magnetic Tape 
System as soon as the Gulp itself is finished, and im- 
mediately proceeds to process the information, while 
the Tape Controller performs the repositioning as a 
"time-shared" operation. Extensive self-checking 
circuitry guarantees the integrity of the repositioning, 
and the operation is completely inter-locked so that the 
Processor cannot perform another operation involving 
that Controller until repositioning has been completed. 
The repositioning takes so little time that, in practice, 
the Processor rarely has occasion to wait for it. 



WRITE TAPE: 

The recording of information from Processor 
memory onto magnetic tape is performed by the WRITE 
TAPE instruction, which writes one or more records as 
a single operation. As each record is written on the 
tape, it is automatically bounded by a BRM (Beginning- 
of -Record-Mark) and an ERM (End-of -Record-Mark); 
thus even though a number of records are written by a 
single instruction, they remain separate entities, and may 
later be searched for or read independently and selec- 
tively. 

All the records written by a WRITE TAPE in- 
struction may be of the same length ("fixed" length), 
or they may be of different lengths ("variable" length). 

Thus the abilities of WRITE TAPE are: 

1) Write 1 to 99 fixed-length records at a Gulp, all 
records of the same length, 10 to 100 words. 

2) Write 1 to 99 variable-length records at a Gulp, each 
record may be of a different length and may be 
10 to 100 words long. 

READ TAPE: 

The reading of information from magnetic tape 
into Processor memory is performed by the READ 
TAPE instruction, which reads 1 to 99 records at a 
Gulp, either fixed-length or variable-length recordis. 

A variation of the READ TAPE instruction will 
read only a selected portion of each record, while the 
remaining information will not enter the Processor 
memory. 

Other variations (Index Forward, Index Backward) 
will move a magnetic tape forward or backward 1 to 
99 records without any of the information entering the 
Processor memory. 

WRITE-COPY: 

When updating a magnetic tape file, the trans- 
actions are always sorted into the same account-number 
sequence as the records in the file. Therefore, when an 
active record has been read into the Processor memory 
from the "father" tape, and all transactions affecting 
that account have been posted to it, and the updated 
record has been written on the "son" tape, the System 
must then start reading all the subsequent records on 
the "father" tape. These records must be examined one 
by one, and each of them must be compared with the 
next transaction to see if it is affected by that trans- 
action (i.e., if that account is active today). As each 
record is found to be inactive, it must be written un- 
changed on the "son" tape, and the process is repeated 
over and over until the next active account is reached. 

Tape-to-tape COPY transcribes the inactive records 
in a file from "father" tape to "son" as a single con- 
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tinuous operation, without reading those records into 
the Processor memory. During this transcription, each 
record is examined, so that the operation terminates 
when it reaches the next active account. 

The functions of the WRITE-COPY instruction 
are: 

1) It WRITES one record from memory. This record 
will previously have been read into memory and 
updated there; in its changed form it must now be 
recorded on the "son" tape. This step is omitted if 
the record is to be deleted from the file. 

2) Immediately after that record has been written, the 
Processor tells the Magnetic Tape Controller which 
record is desired next, and thus initiates the off-line 
COPY from "father" to "son". The Processor is 
now free to proceed with any other work which 
does not use that Controller, while the Controller 
is looking for the next active record and transcribing 
all intervening inactive records from "father" to 

son . 

The Controller conducts the COPY independently 
of the Processor, moving both tapes continuously, and 
transcribing character by character from "father" to 
"son" while the two tapes are in motion. As the in- 
formation flows through it, the Controller examines 
each record to determine if it is the desired one. When 
that record is reached, the Controller stops both tapes 
and repositions them so that the "father" is ready to 
read that record into the Processor memory, and the 
"son" is ready to write that record from the Processor 
memory after it has been updated. While the COPY is 
going on, the Controller reports "busy" so that the 
Processor continues with its alternate program until 
the COPY is finished. 

Any of the first 8 words of each record may be a 
"key word" containing Account Number or other 
identification, and the Controller will examine any 
desired selection of characters within the key word, 
ignoring all other characters. Further, the key word 
may be divided, with the Controller testing two differ- 
ent keys simultaneously. A common use of this feature 
considers Account Number (up to 10 digits condensed 
into 7 characters) as one key, and "next-action" Date 
(day, month, year, century, coded into 3 characters) as 
the other. The Account Number is compared with the 
next transaction, while the Date is compared with to- 
day's date, so that COPY finds all accounts for which 
transactions were received today, and also all accounts 
requiring some action (billing, follow-up, expiration, 
etc.) today. 

Two types of test may be used with COPY: 

Equality COPY will terminate when it reaches the 
desired record. 

Range COPY will terminate when it reaches either 
the desired record, or else a record whose key is 



greater than the one desired. The latter case occurs 
whenever the desired record is not in the file, which 
usually means that a new account has been opened, and 
a new record must be inserted in the file. 

When the key word is divided, either side of the 
key may be tested for Range or for Equality, independ- 
ently of the kind of test being performed on the other 
side. 

SEARCH; 

A variation of COPY uses only the "father" tape, 
and therefore accomplishes off-line SEARCH of 
magnetic tape. 

WRllE-COPY-READ: (on-line Copy) 

This operation is essentially the same as WRITE- 
COPY, together with the subsequent READ, executed 
as a single continuous operation. It requires supervision 
by the Processor itself, and is used whenever the 
particular problem does not offer any useful work for 
the Processor to do during the COPY. In that case, 
terminating the COPY with the desired record in the 
memory elminates all delay between the COPY and the 
READ. 

SEARCH-READ: 

A variation of COPY-READ uses only the "father" 
tape, and therefore accomplishes on-line SEARCH- 
READ of magnetic tape. 

REWIND: 

The rewinding of any reel of magnetic tape is 
initiated by the REWIND instruction. The actual re- 
winding is performed entirely by the Magnetic Tape 
Handler, so that both the Processor and the Controller 
are immediately free to do other work. Any number of 
Handlers may be rewinding at the same time without 
interfering with the rest of the System. 

A variation of the REWIND instruction will place 
a USE LOCKOUT on the Handler so that the Processor 
cannot use it again until its reel of tape has been 
changed. 
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MAGNETIC TAPE HOUSEKEEPING 

The National 304 Magnetic Tape System, together 
with the subroutine called STEP (Standard Tape Execu- 
tive Program), relieves the programmer of all tape 
"housekeeping" problems. 

The Magnetic Tape System automatically detects, 
and automatically identifies, ALL housekeeping condi- 
tions (such as Busy, Use Lockout, Error, End of Tape, 
End of File, etc.) and automatically establishes appro- 
priate branches in the program. For all routine matters 
these branches lead to STEP, which takes care of the 
situation and then returns to the main program without 
attention from the programmer. Thus, for example, 
when a Handler reaches the end of a reel of tape, STEP: 

• Rewinds that Handler; 

• Types-out Controller and Handler number on 
the Console Typewriter; 

• If Source Tape, types-out to indicate which reel 
of tape must next be mounted on that Handler; 

• If Destination Tape, types-out to indicate what 
identification should be placed on the outside of 
the reel; 

• Changes the entire main program to refer to an 
alternate Handler for the next reel in that file; 

• If Source Tape, checks the first record on the 
next reel (containing tape-identification) to be 
sure the correct reel has been mounted; 

• If Destination Tape, checks the first record on 
the next reel to be sure the tape is obsolete and 
is safe to write on. Then STEP writes a new first 
record on the tape to identify the information 
about to be recorded on it; 

• Returns to the main program, which proceeds 
as though nothing had happened. 

STEP corrects errors in recording or reading tape, 
and it identifies defective spots on the tape and skips 
over them, all without attention from the programmer 
or the operator. 

STEP also brings in Overlay Programs on demand, 
and automatically steps the Processor from program to 
program. 

Out of all possible housekeeping circumstances, the 
programmer must plan for Busy, if he wishes to utilize 
the system's ability to perform other operations simul- 
taneously; and he must plan for End of File, because 
that means the program is finished and the Processor 
must proceed to the next job. Aside from these, he 
writes his programs as though all magnetic tapes were 
endless, and as though all other housekeeping problems 
could never arise, because the Magnetic Tape System 
and STEP detect, identify, and correct all those condi- 
tions. 



GUARANTEES OF TAPE ACCURACY 

In any Electronic Data Processing System the only 
way to be assured that the recording on magnetic tape 
is as it was intended to be, is to READ the tape and test 
its correctness. Further, this reading should be done at 
the one time when an error, if it should occur, can be 
corrected most easily. That time is immediately after the 
information has been recorded, since only then is the 
correct information still available in the Processor 
memory. 

The National 304 System automatically reads, and 
checks, the magnetic tape during the recording process. 
If a recording error should occur, it will be discovered 
immediately, and may be corrected automatically with- 
out guesswork, and without operator intervention. This 
procedure guarantees, at the time of recording, that all 
tapes are recorded without error. 

The read-checking of magnetic tape recording is 
performed by a reading head located on each Handler, 
immediately behind the writing head: 



FORWARD 




As the newly recorded information passes under 
the reading head, it is read and immediately checked by 
the Controller. The self-checking system is extremely 
comprehensive, and consists of five basic checks, so 
organized that any possible source of error is covered 
by at least two independent checking methods: 

7. CHARACTER PARITY: 

Each character is recorded with a parity bit. This 
seventh bit is assigned automatically, and is chosen so 
that the seven bits of each recorded character always 
contain an odd number of 1-bits. 

This check protects against the garbling of in- 
dividual bits within the characters of the record. 

2. RECORD PARITY: 

One extra character is automatically recorded with 
each record. The Controller sets up the individual bits of 
this character so that there is always an odd number of 
1-bits along each of the diagonal arrows shown in the 
diagram. 

This furnishes independent protection against gar- 
bling of bits, and also protects against the omission of 
complete characters or the accidental recording of addi- 
tional, spurious characters. 
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RECORD-PARITY 
CHARACTER 



INFORMATION 
CHANNELS 



CHECK-BIT CHANNEL 



RECORD-MARKER CHANNEL 
Markers not shown 




ONE RECORD 
SELF-CHECKING OF INFORMATION ON MAGNETIC TAPE 



3. CHARACTER COUNT: 

Each record must contain an exact multiple of 10 
characters, plus the record-parity character. 

This is a consequence of always recording complete 
words from memory, and furnishes important inde- 
pendent protection against dropping or adding char- 
acters on the tape. 

4. ERM-BRM ALTERNATION: 

Whenever a tape is in motion, the record-markers 
must always show perfect alternation between ERM and 
BRM, to guarantee the boundaries of each record. 

Even if exactly the three bits of a record-marker 
pair (and no other bits in that channel) should be acci- 
dentally changed, checks 2 and 3 each furnish inde- 
pendent detection of this condition. 

5. TIMING CHECK: 

Whenever a tape is started into motion, the 
Controller sets a rigid time-limit within which the 
Handler must detect the first record-marker. This check 
is made at the writing head when writing, and at the 
reading head when reading. 

When the record-marker is detected within the 
time-limit, it is certain that the very next record on the 
tape is the one which was written or read. 

5a. FIRST-INFORMATION CHECK: 

Whenever a Handler is about to read or write the 
first record on a reel of tape, the Timing Check is not 
appropriate, since it is desirable to leave several feet of 
blank tape at the beginning of the reel, and this would 
cause the time-limit to be greatly exceeded. Therefore, 
when the Handler senses that the tape is positioned on 



the leader, the Timing Check is automatically replaced 
by the First-Information Check. 

When writing at the beginning of a tape, the 
writing head erases the first three feet of the tape, and 
then writes the first record. The reading head must 
then find that a record-marker is the first information 
on the tape. Nothing, not even recording so faint that 
it is detected only as undecipherable "noise", may ap- 
pear on the tape before the first record-marker. 

These five checks are made by the reading head 
while the writing process is going on, and they guaran- 
tee that all tapes are correctly recorded. 

The same five checks are also made during the 
reading process, and guarantee that all tapes are cor- 
rectly read. During a Copy, these checks are made on 
both the "father" and "son" tapes. 

The Timing Check, and the ERM-BRM Alternation 
Check, are also made on all repositioning operations. 



INTERLOCKS 

J. WRITE LOCKOUT: 

Every Magnetic Tape Handler is normally in a 
Write Lockout state, in which the recording circuits are 
completely disconnected. In order to engage the writing 
circuits, and permit information to be recorded on a reel 
of magnetic tape, it is necessary to affix a "write- 
permissive" ring to that reel. 

In the absence of this ring, it is impossible, whether 
through operator error, programmer error, or equip- 
ment malfunction, to write on and thereby destroy a 
tape whose information is still useful. 
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If a ring is accidentally left on a reel after it is 
removed from tfte Handler, there will be no ring avail- 
able to place on the next reel; further, the reel will not 
fit into its plastic storage-box if the ring is still attached 
to it. 



4. MOUNTING OF TAPES: 

Unless a reel of tape is correctly mounted, and the 
cabinet door properly closed, it is impossible for the 
operator to remove the Use Lockout from the Handler. 



2. USE LOCKOUT: 

When the end of a tape has been reached, and the 
rewind has been started, the program may impose a Use 
Lockout on that Handler. This prevents any use of that 
Handler until the tape has been completely rewound, 
and an operator has mounted a new reel. 

3. HANDLER DOOR LOCKED: 

The door to the Handler cabinet, furnishing access 
to the reel of tape, is always locked by an electrically- 
operated bolt, except when the Handler is in Use Lock- 
out and the tape is not moving. Therefore the operator 
is denied access to the tape except when the program 
has finished with it. Even during a rewind with Use 
Lockout, the door remains locked until the rewind is 
completed. 



5. NO TAPE, BROKEN TAPE: 

If the Processor attempts to use a Handler which 
does not have a tape mounted on it, or if a tape should 
break, an immediate error-halt occurs. 



6. LONG LOOP, SHORT LOOP; 

In the event that either of the tape loops in the 
vacuum chambers should grow, or shrink, beyond the 
capacity of the servo system to correct the condition, 
there would be a danger of breaking or of crumpling 
the tape. Special independent circuitry detects this con- 
dition before damage occurs; the tape drive is imme- 
diately released, the brakes are set on the reels, and the 
Handler error-halts. 
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GENERAL CHARACTERISTICS OF THE PROCESSOR 

A fundamental characteristic of any Electronic Data Processor 
is its internal infoiroation-storagej or "Memory", in ishich it is able to 
store both that part of the data being operated upon at the moment, and 
the program for processing that data. The program is a seqtaential list 
of Instructions, each of which (such as ADD, COMPARE, READ MAGNETIC TAPE) 
represents a single operation to be executed by the Processor. 

The NCR 304 Data Processor is available with a Memory of either 
2000 or 4000 permanently-numbered storage locations, or "Cells", which 
contain stored infomation. The number assigned to each Cell is the 
"Address" of that Cell. In addition to the basic 2000 or 4000 Cells of 
Memory, there are, respectively, 400 or SOO "Special" Cells, outside the 
Main Memory package, -which are all individually addresslble by any In- 
struction. These "Special" Cells are described, with the limitations and 
conventions governing their use, in Appendix "C" to this Chapter, 

The contents of each Cell is a "Word" of 10 characters, and the 
character-positions within a Word are conventionally numbered from right 
to left? 

9 876543210 

] '■ ■ ■ ' -1 

i « 1— U 1 _! 8.^ _l _t J__ — 1 

Information is stored in Memory by means of Magnetic Cores, 
which are tiny ilngs of ferrite material, strung on a lattice of wires <, 
Each core may be selectively magnetized in either of two states which, 
for convenience, are designated "0*' and "1"« The symbols "0" and "1** are 
not numbers. They are merely convenient marks used to distinguish the two 
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states of a single Magnetic Gore. Any other pair of conventional symbols 

wotild serve as well, for examples 

"N>» and ^'S>' ".» and ^*~" ^l^' and 4*^ "o" and »V»» "-^^ and »-'* . 

However, "0" and "1" are in common "Qse, and we shall tise them in this book, 
subject to the caution that they mxist not be thought of as numbers . The 
marks "0" and "1", corresponding to the two possible magnetized states of 
one core, are called "bits", and therefore a single core may store either 
a "0-bit" or a "1-bit". 

Six cores are assigned to each character-position of each Cell 
in the Memory, and characters are spoken of as being represented by a 
6-bit code. Since each bit has only two "values", the bit-configuration 
of a character is called the "binary" (2-way) representation of that 
character. There are 64 possible combinations of the "0" and "1" states 
of each group of 6 cores, corresponding to the 64 different characters 
in the "language" of the Processor. A character may be a numeric digit, 
a letter of the alphabet, or one of 28 symbols. 

It is convenient, when speaking of the 6-bits which make up a 
character, to classify them into "zone bits" and "numeric bits", and to 
write them in the following pattern: 

zone numeric 
00 0000 
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The 64 characters of the Processor language, and their 
respective 6-bit binary configurations are: 





NUMERIC 














NUMERIC BITS 












ZONE 


VALUE OF 


























BITS 


ZONE BITS 


0000 


0001 


0010 


0011 


0100 


0101 


0110 0111 1000 1001 


1010 


1011 1100 


1101 


1110 


nil 


00 








1 


2 


3 


4 


5 


6 7 8 9 


@ 


^ 


SPACE 


& 


• 


» 


01 


1 


— 


A 


B 


C 


D 


E 


F G H 1 


D 


A 


m 


n 


f 


P 


10 


2 


+ 


J 


K 


L 


M 


N 


» P Q R 


% 


£ 


$ 


( 


) 


/ 


11 


3 


* 


# 


S 


T 


U 


V 


W X Y Z 


d 


s 


u 


Y 


w 


X 



Every one of the 64 possible configurations of 6-bits corre- 
sponds to a legitimate character in the Processor language. However, 
56 of these (called the "Data Characters") are sufficient for all business 
data requirements. The remaining S characters, lower-case mnc^p :ivwx, 
are simply convenient labels for their respective bit-configurations, and 
are referred to as "Non-Data Characters". 



III-3 



BEPRESMTATION OF INFORMATION 

Information stored in Memory may constitmte either Instructions or 
Data. There is no absolute distinction between the two types of information^ 
since one of the fimdamental properties of an Electronic Data-Processor is 
its ability to operate mpon its own Instructions, and modify them as though 
they were Data* 

INSTRUCTIONS ; The program for processing the Data is stored in Memory as a 
list of Instructions, which the Processor executes in sequence. An Instruc- 
tion may specify that a certain operation be performed upon Data, or that a 
test of some sort be performed. Depending upon the result of the test, the 
Processor may continue to execute Instructions in the normal sequence, or 
break the sequence and start a new sequence elsewhere in the program. Break- 
ing the normal seq-uence of Instructions is called ^'Branching" or "Jumping", 

A substantial number of the Instructions in the 304 System serve 
both purposes; they may perform an extended series of operations upon Data, 
and then test the result as well. 

DATAs The basic unit of Data within the Processor is the Field , which occupies 
all, or any continuous portion, of a Word. A Field is specified by naming the 
address of the Word containing it, and the left-most and right-most character- 
positions occupied by the Field within the Word. Thus, suppose that the con- 
tents of some Cell in Memory iss 

r.a .? ,6,5,4,3.2.1.0 



2 3 9' 2 1 J N E S 

— -i 1 — JL_ — J _L_ I y < i ^ 



Then; theniamber 2392 occupies the 96~field of that Cell, 

the niamber 3921 deemples the 85-field of that Cell^ 

the name JONES occupies the 40-field of that Cell, 

the niamber 1 occupies the 55^field of that Cell. 

111-^4 



The Data stored in a Field may take one of three foims: 

1) ALPHABETIC IMPORMATIQN : 

This is sometimes referred to as "alphanumeric" information, and 
may consist of any combination of the 64 digits, letters, and symbols, which 
make up the Processor language. 

2) NUMERIC INFORMATION with algebraic sign: 

A Numeric Field consists of digits, representing a number. The 
algebraic sign of that number is combined with the left-most digit of the 
Field, and is specified by the right-hand zone bit of that digit. If this 
"sign-bit" is a 0-bit, the algebraic sign of the entire Field is positive; if 
the "sign-bit" is a 1-bit, the algebraic sign of the Field is negative. 

Consequently, the left-most character of a Numeric Field always 
contains two pieces of information: the sign of the Field (specified by the 
sign-bit), and the first digit of the Field (specified by the numeric bits). 
In all arithmetic operations, the Processor automatically handles the signs 
in the proper manner, and properly stores the sign of the result; the pro- 
grammer need never concern himself with the problem of storing algebraic signs, 
or even of allocating storage-space for the signs. 

Consider the number 942 stored in a 5-character field; it will ap- 
pear as 9 4 2 where the first "0" has the double significance "positive" 
(sign-bit) and "zero" (numeric bits). If the same number were stored in a 
3-character field, it would appear as 9 4 2 where the "9" has the double 
significance "positive" and "9". (Refer to the Language Code Table for the 
binary configurations of "0" and " 9" ) . 

Consider the number -174 stored in a 5~eharacter field; it will 
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appear as - 17 4 where the hyphen "-" has the domble significance "negative" 
(sign-bit) and "zero" (ntameric bits). If the same number were stored in a 
3-character field, it would appear as A 7 4 where the "A" has the domble sig- 
nificance "negative" and "1". (Refer to the Language Code Table for the 
binary configurations of "-" and "A" . ) 

Since the combined representation of "positive" and "zero" is the 
character "0" (zero), and the combined representation of "negative" and "zeiro" 
is the character "-" (hyphen), all input and output is conveniently performed 
in conventional format; that is, positive numbers preceded by no sign (but 
note that if "+" is used, it is also interpreted arithmetically as meaning 
"positive" and "zero"), and negative numbers preceded by a hyphen. 

Appendix "A" to this Chapter discusses the disposition of redundant 
zone bits during arithmetic operations, and also shows the resiilts of per- 
forming arithmetic operations upon characters whose numeric bits do not cor- 
respond to any of the 10 decimal digits. 
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ADDRESS-TYFE INFORMATION: 



The Cells of Memory are ntmbered: 



000 throtigh 099 
100 through 199 



900 throiigh 999 



Reads 

"Hyphen zero-zero" I -00 through -99 

"Hyphen NiNETY-NtNE» | AOO through A99 

• * • * 

« • • • 

100 through 199 

+00 through +00 
JOO through J 99 



ROO through R99 

-"■00 through ""-99 
#00 through #99 
SOO through S99 



ZOO throtigh Z99 



■\ 



y 



J 



2000-Word 
Memory 



■^ 



> 



Z|.000-¥ord 
Memory 



J 



In order to perform arithmetic operations on Addresses, a special 
kind of addition and subtraetion^ called MODIFY ADD and MODIFY SUBTRACT, have 
been included among the Processor operations; the symbols ® and are used to 
distinguish them from ordinary addition and subtraction. 

Subtracting one Memory Address from another gives the number of 
Cells separating them, expressed as an "Address -Type Number" . In order for 
the programmer to duplicate the Processor's result of a MODIFY ADD or MODIFY 
SUBTRACT, or for him to interpret the Address -Type answer, he may regard any 
Address-Tjrpe Number as a condensed fonn of a 4-digit nimiber from 0000 to' 
3999, in which the left-most two digits have been combined into the zone bits 
and the numeric bits of a single alphanumeric character. The zone bits of 
this character specify the first digit, according to the column "Numeric 



III-7 



Yaliie of Zone Bits" in the Language table, and the numeric bits of this 
character specify the second digit. Thus, for example, the Address -Type 
number G55 May be interpreted as 1755. The zone bits of "G" have the ntmeric 
value "1", and the niameric bits of "G-" are the numeric bits of "?'*. Several 
other examples follows 



Address-T3rpe 


Interpreted 


Number 


As 


001 


0001 


L07 


2307 


er99 


2699 


X21 


3721 


Z9S 


399s 



The following rules, then, will enable the programmer to duplicate 
the answer which the Processor obtains as the result of a MODIFY ADD or MODIFY 
SUBTRACT operation; 

1) Interpret the two Address-Type lumbers which are to be added 
or subtracted, as 4--digit numbers. 

2) Perform the addition or subtraction. 

3) If the result is greater than 3999> subtract 4000 from it. 
If the result is negative, add 4000 to it. 

4) Translate the result back into an Address~Type Number. 

EXAMPLES ; 998 B OO^ = ::^ 99S- — > 099B 

This result is NOT "mikos ©2'* 5 ^^a ^ ^ 5||| 



IT IS "HYPHEN ZERO TWO«». 



~02-e- 



150 ® :M = m H50 ^ 1850 

@ 10^ > + 0305 

2155 
J55^_ . 



Z21 ® £M '= Mi F21 — ^ 1621 

^ @ J^ — >- + 2144 

3765 
X65< —J 



III~8 



EXAMPLES ; (Cont«d) 

P39 @ f^ = Gao 



P39- 



2739 



© fy, — > + 3041 

5780 (greater than 3999) 
- 4000 



G80<- 



1780 

I 



P39 Q ^^41 = ¥98 



P39— > 
a ^^ ^ 

W98.«^ — 



2739- 
3041- 



negative 



6739 
3041 
3698 



B83 @ Z12 =* Mi 



B83 — > 1283 
@ 199 — ?" + 3999 

5282 (greater than 3999) 
- 4000 
1282 
B82< J 



It will be seen that the operations of MODIFY ADD and MODIFY SUBTRACT 
are "cyclic modiilo 4000" j that is, the address following Z99 is 000, and in 
performing arithmetic, the addresses may be regarded as being arranged in a 
circle. Any counting process which crosses one "end" of the Memory picks np 
without a break at the other "end" as shown in the previous examples. Note 
also that there are no negative ntimbers in the system of Address-Type Nombers; 
no algebraic sign is associated with them, and they are always positive 
nmibers. However, the last example shows the use of "complementary addition", 
in which Z99 is equivalent to "~1" . 

Whenever an Instruction specifies the number of Words, or the number 
of Items, to be operated upon — or whenever the Processor itself generates a 
tally — such a number is always an Address-Type Number. 

Appendix "C" to this Chapter discusses what happens if an Instruc- 
tion refers to some non-existent address, such as L31 in a 2000~Word Memory, 
or &76 in any Memory. 
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One of the frnidamental principles of programming must be made clear 
at this point. The nature of information stored in the Processor Memory is 
known only to the programmer; it is in no way inherent in the information 
itself. For example, a field might contain U B Q R 6 9 » If this field is 
named as containing an operand for an arithmetic Instrtiction, its contents 
■will be interpreted by the Processor as the negative number --4SS969 (see 
Appendix "A"). If this field is named as containing an operand for an 
Instruction appropriate to Address-Type lumbers, its contents vdll be in- 
terpreted as the pair of Address-Type Numbers US8 R69 (see Appendix "B"). 
If the same field is named as containing an operand for one of the general 
data-handling operations, its contents will be interpreted as the set of 
alphantameric characters USQR69. 

On the other hand, the Processor might be instructed to find its 
next Instruction in the Cell in which that field is stored. In this case, 
the field loses its identity, and its characters become part of the 
Instruction, to be interpreted according to the specific format of that 
Instruction. 
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INSTRUCTIONS 

Instructions in the NCR 304 System are in 3~address form. An 
Instruction (in general) names an operation to be performed, the addresses 
of two operands, and the address in which the result is to be stored. 

This principle, however, has been very considerably expanded, so 
that execution of each Instruction includes most of the attendant "house- 
keeping" chores which ordinarily complicate the programmer's task. As a 
result, each Instruction is an entire unit operation , corresponding very 
closely to an operation as it is naturally conceived by the Systems 
Analyst without reference to any Data Processor. The comprehensiveness 
of each Instruction, the elimination of almost all housekeeping Instruc- 
tions, and the consequent relief from the necessity of storing large 
numbers of Constants in a program, combine to make the System extremely 
easy to program, and to eliminate many sources of programming errors. 



III-ll 



An Instruction specifies the follovdng factors governing an opera- 



tion: 



•JBBJ- In addition to the actual Operation Code, each Instruction contains 
a Variation Designator, since most operations have several possible variations. 
For example, a MULTIPLY Instruction may yield either a full-length product, or 
a product which has been roxmded off to any desired number of digits, depend- 
ing on which variation of MULTIPLY is used. 

The Variation Designator also governs the Self -Linking facility, 
described later in this chapter. 

■iHi-jf 4jj Instruction names not only the addresses of the Cells containing 

the operands, but also the respective partial -word fields in thse Cells. 

Thus, an Instruction might specify: 

Add: Contents of 53-field of Cell 250 

Plus: Contents of 31-field of Cell 462 

Store: Result in 85-field of Cell 721 



The operation will be performed as follows: 



437 
+ 934 

1371 



9 8 76543210 



ililiiiii 4.3.7 liiilii 



w^^mm^XM 


9 3 4 


ii 



8 2.6.7.0.0,4.2 ,3.5 



m 


1,3,7 1 


iiiiliiiSi 



Cell 250 

Cell 462 

Cell 721 before operation 

Cell 721 after operation 



The Processor automatically isolates each of the operands, aligns 
them at the right (Right-Justifies them), performs the addition, and inserts 
the result into the designated putaway-f ield without disturbing the contents 
of the rest of the putaway Cell. 
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^^■^" Any of the addresses named in an Instruction mslj be modified, dmrini 
exec-Tition of the Instruction, by the contents of an Index Register (Relative 
Address Register) . 

The ten Cells, OOP through 009 have the special property that they 
may be used as Index Registers. They are in every respect ordinary Cells in 
the Processor Memory, and may be referred to by any Instruction without re- 
striction, just as any other Cells; but they have the additional ability to 
serve as Index Registers when required, and are conventionally reserved for 
this purpose. 

Each Instruction designates one of these ten Cells as an Index 
Register for that Instruction, and also specifies which of the addresses 
named in the Instruction are to be modified. At the programmer's options 

-^ none of the addresses, 

- any one of the addresses, 

- any two of the addresses, 

- all three of the, addresses, 

may be modified by the contents of the corresponding fields of the designated 
Index Register, 

When an Instruction is about to be executed, the Processor copies 
that Instruction into its "private" working -registers (which are not accessi- 
ble to the programmer). The Processor changes this copy of the Instruction, 
by MODIFY ADDING the contents of the corresponding field of the Index 
Register to each of the designated addresses in the Instruction. Then the 
changed copy of the Instruction is executed by the Processor. 

An address named in an Instruction, therefore, is not necessarily 
the actual address of an operand or of a putawayj it is the base of the 
address. If that address is relative to an Index Register, then the base 
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is a-ugmented hj the contents of the corresponding field of the Index Register to 
obtain the actual address * 

Mote that the Instnaction itself, stored in Memory, is never changed 
by the use of an Index Register. Every time an Instruction is to be executed, a 
new copy of the Instruction is set up, modified by the Index Register, and it is 
this iiodified copt of the Instruction which the Processor executes. 

By making a series of Instructions all relative to the same Index 
Register, the programmer avoids the necessity of pre-setting and modif3d.ng each 
Instruction in the series. Modifying the contents of the Index Register has the 
effect of temporarily modifying (at the time of execution) every Instruction which 
is relative to it. 

Some of the situations in which the Index Registers are used to ad- 
vantage are: 

- magnetic tape file management, 

- working with multiple file records, 

- table lookups, 

- distribution and analysis. 

- programming repetitive loops. 

-JBBJ- f^Q HGR 304 System has very extensive automatic facilities (discussed 
in Chapter ¥) for selectively monitoring execution of the Instructions in a pro- 
gram, as an aid in program-checking o Some of these facilities make use of a 
Monitor-level Bigit, which is part of each Instruction, 

^BH(- Many Instructions perform long series of operations, equivalent to com- 
plete subroutines, and require that additional factors be specified to define the 
total operation. 

-)HB(- The contents of certain character-positions within some Instructions 
are irrelevant to the operation. These positions may be used to store a substan- 
tial portion of whatever constants are required by the program. 
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INSTRUCTION FORMAT 

An arithmetic Instruction, such as ADD, may be taken as typical 
of the foniiat of the 304 Instructions. This basic format is varied and 
expanded to meet the requirements of all the Instructions. 



First Word 
Second Word 



9 




7 


6 


5 4 

1 


3 


2 

1 


1 

1 1 1 


Op 


A 


B 
1 1 


C 
1 1 




V 


M 


S 


R 


At^AR 


Bl,br|cl ,cr 



Op! Operation code. 
M: Automonitor level: 0, 1, 2, 3. 

S: Selects addresses for modification by Index Register COR. 

In many Instructions , the fields of the first word of the 
Instruction contain something other than addresses; never- 
theless, the contents of these fields are modified just 
like addresses. 

The precise significance of S is explained on the next page. 

R: Designates Cell OOR as Index Register. 

A: Base of address of first operand. 

Al, Ari Locations of left-most and right-most character-positions, 
respectively, of the first operand. 

B: Base of address of second operand. 

Bl, Br; Locations of left-most and right-most character-positions, 
respectively, of the second operand. 

C: Base of address in which the result is to be put away. 

Cl, Gr: Locations of left-most and right-most character-positions, 

respectively, of field allocated to the putaway of the resiilt. 

V: Variation designator. 
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SELECTIVE MODIFICATION OF FIRST WORD OF INSTRUCTION 
BY AN INDEX REGISTER . 



The three fields of the first -word of an Instruction, which 
normally contain addresses , are called the syllables of that word. Each 
of these syllables Is regarded as having an assigned "S-value" in connec- 
tion with the digit S in the Inst ruction format: 

the 86-fi eld is the A syllable, with S-value 4 
The 53~field is the B syllable, with S-falue 2 
The 20-field is the C syllable, with S-value 1 

When the progranamer has determined which syllables of an In- 
struction are to be relative to the designated Index Register^ he adds 
the S-values of those syllables, to obtain the value of S. 



S -value 
4 
2 


A syllable modified 
B syllable modified 


S-values of syllables 


1 
Sum 


G syllable modified 
Determines combination 


4 

,-_^..t......,...i ....... .. 


2 

.W. »„„■ rh .. , 


1 
t » 



of syllables modified. 
li* S = « no Index Register is used, and R is irrelevant. 



S = 0: No syllables modified 

S = 1j G syllable modified 

S = 2: B syllable modified 

S = 3s B and G syllables modified 

S = 4s A syllable modified 

S = 5j a and G syllables modified 

S = 6: A and B syllables modified 

S=7: A, B,G syllables modified 
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OPERATION OF THE 



SEQUENCE-CONTROL REGISTER 



The Processor uses the 53~field and the 20-field of Cell ^00 
as the Sequence-Control Register. Cell ^00 is one of the "Special Cells" 
mentioned on page III-l, and described in Appendix "C". 



9876543210 



Cell ^00 



I , . ■■■. . . 4. 



I .. I , I I I 



P Q 
» I I 1 — 



The 20-field contains Q, the address of the first word of the 
next Instruction to be executed in the Program. In order to execute it, 
the Processor copies the Instruction into its working-registers, and at 
the same time augments Q by the number of words in the Instruction. For 
the moment, then, the new value of Q is the address of the next Instmaction 
in the normal sequence . 

The copy of the Instruction, in the working -registers , is then 
appropriately modified by the contents of the designated Index Register, 
and the modified copy of the Instruction is executed. If the Instruction 
causes a branch in the program, the new value of Q is automaticsilly re- 
placed by the branch address named in the Instruction, 

Thus, whether or not the Instruction causes a branch, the 
Processor will always find the address of the next Instruction in the 
20-field of Cell ^00. 
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If the ¥ariat ion Designator of an Ins traction is negative, 
(if the sign-bit of £ is a 1-bit), then -onder certain circumstances P 
and Q will be interchanged in 00, as part of the execution of the 
Instnictions 

Decision Instruction which does hot branch ; 

No interchange takes place, regardless of the sign of T* 

Decision Instruction which branches g 

The Processor makes the decision to branch; if V is negative, 
P and £ are interchanged; then the branch address named in the Instruc- 
tion is stored in the 20-field of 00 in the usual manner. 

In this way 2 3 the address of what would have been the next 
Instruction if there had been no branch > is retained in the 53-field of 
00, and can serve as a link back to the branch-point at a later time. 

Sequential Instruction : ■ 

When execution of the Instruction has been completed, and the 
result has been stored, then if ¥ is negative, P and Q are interchahged 
before selecting the next Instiniction f5r fexectition, with the result 
that the next Instruction is selected from the address initially stored as P. 

Thus any sequential Instruction can impose a Jump, and store 
a return link. 
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Since Cell ^00 is fully addressible, and is accessible without 
restriction^ the prograramer has a great deal of freedom in branching and 
linking. Some of the techniques are: 

1) Branch without linking ; 

Use a decision Instruction, V positive. If a link had pre- 
viously been stored as P, it will be undisturbed. 

2) Branch, and link back to the branch -point ; 

Use a decision Instruction, V negative. The link address will 
be preserved as P. 

3) Branch, and link to some other point in the program ; 

Use any appropriate Instruction to store the address of the 
link-point as P. Then, for the branch, use a decision 
Instruction, V positive, which will not disturb P. 

4) Return to the linl^-point ; 

Make Y negative in the last Instruction (which will be a 
sequential Instruction) of the branch sequence, 

5) ConditiomaUy return to the link-point : 

In the branch sequence, use an appropriate Instruction to pick 
up P and store it as the branch address named in the decision 
Instruction. 

6) Jump unconditionally without linking ; 

Use an appropriate Instruction, V positive, to store the jump 
address as Q. Any link previously stored as P will be xm- 
disturbed. 

7) Jump \mconditionally and link ; 

Use an appropriate Instruction, V negative, to store the jump 
address as P. Since V is negative, P and Q will be inter- 
changed after the putaway, establishing the jump and the link. 

B) Jump unconditionally, and link to some other point ; 

Use an appropriate Instruction, V positive, to store the 
link address and the jump address as P and Q respectively. 



III-19 



The compiete execution cycle of a standard Instruction (except 
for automonitoring) is shown in the following flow-chart: The 
notation «00:20) means *'The contents of the 20-field of Cell <00" 



START 



NO 



Copy contents of the cell named in ^00:20 (first word 

of the Instruction) into working-register X. 
Augment: {^00:20)01. 

Copy contents of the cell now named in ^00:20 (second 

word of the Instruction) into working-register Y. 
Augment: (fzf00:20) ©1. 

Check for Overflow Condition (See TEST OVERFLOW, 
Chapter IV). 

YES 



Modify specified syllables in working-register X by 
contents of the designated Index Register. 

Execute the modified copy of the Instruction which 

is in working-registers X and Y. 
(The Instruction may refer to ^00 without restriction). 

What kind of Instruction was it? 



-►OVERFLOW HALT 



SEQUENTIAL 



DECISION 




y J y 



What is the sign of V? 



Interchange 

()z;00:53) and (fzf00:20) 




Does the decision result 
in a branch? 



What is the sign of V? 



Interchange 

(|2fOO:53) and (^00:20) 



Store the jump address 
in j^00:20 



TO NEXT INSTRUCTION 
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SELF-CHECKING OF INFORMATION STORAGE 

All storage of information in magnetic cores, and all trans- 
mission of information between units of the System, are automatically 
checked. 

Every vrord in the Processor Memory is actually stored as 11 
characters — the 10 characters of the word itself, and one additional 
check-character assigned by the Processor. Each bit in the check- 
character establishes parity along one diagonal of the bits in the word, 
as shown in the diagram: 




When information is to be read from Memory, an entire word 
is read into a working register, and the check-character verified. Then 
the appropriate field is selected from the word, and at the same time 
each character in the field is assigned its own seventh parity-bit. 
Information is stored in all operating registers in the form of 7-bit 
characters, and parity is checked during every readout. 
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When a field is to be stored in Memory, the entire word which 
already occupies the putaway cell is read into a working register, its 
cheek-eharacter verified and a 7th parity-bit assigned to each character. 
Then the information to be pntaway is inserted in the word, a new check- 
character is computed, the parity-^bits of the individual characters are 
dropped, and the revised word is recorded in the putaway cell. 

In all transmissions to and from Input and Output Units, every 
character is transmitted with its pcirity-bit, and parity is checked at 
both ends of the transmission. In addition, all Input and Output Units 
have their own self -checking facilities, described in Chapter VI. 

in recording on Magnetic f ape, every character is recorded 
with its parity-bit, and in addition every record is assigned a diagonal - 
parity check-character. Other automatic checks on Magnetic Taf>e record- 
ing are discussed in Chapter II ^ 

Any failure of word-parity or character-parity within the 
System causes an immediate error-halt, except for Magnetic Tape opera- 
tions, where automatic program branches ai'e furnished to permit repeti- 
tion of the operation. 
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CHAPTER IV 
OPERATIONAL CHARACTERISTICS OF THE PROCESSOR 

The following list illustrates the conventions which have been adopted 
in this chapter: 



CELL 
ADDRESS 
WORD 
FBLD 
22 FIELD 

CELL 241 

CELL 1 

241:72 

241:33 

A: 20 

(241) 

(A) 

(241:72) 

(A:20) 

A-FIELD 



SILLABL^ 



A laemoiy location. 

The mamber assigned to a cell. 

The contents of a cell. 

Any set of adjacent characters within a word. 

The field which extends firom character-position 7 
through character-position 2 within a word. 

The cell whose address is 241. 

The cell whose address is designated bj A. 

The 22 field of cell 241. 

The 22. ^ield (character-position 3 only) of cell 241. 

The 20 field of cell A. 

The contents of eell 241. 

The contents of cell A. 

The contents of 241:72. 

The contents of A: 20. 

An Instruction names A as the base of the address 
of an operand. This base may be modified by the contents 
of an index-register to form the actual address of the 
operand. 

The Instruction further specifies that the operand 
occupies a certain field within its cell. 

The specified field in the actual address of the 
A-operand is referred to as the A-Field . 

The contents of the A-field. 

It is convenient to refer to the three fields of the 
first word of an Instruction, which normally contain 
addresses, as the syllables of that word. 

The A Syllable is the B6 field . 

The B Syllable is the ^ field. 

The G Syllable is the 20 field. 

I?-l 



OVERFLOW ALARI4 



REGISTER 



RIGHT-JUSTIFIED 
LEFT -JUSTIFIED 



Shaded areas in an Instruction Format indicate character- 
positions which are; irrelevant to, the execution of the 
Instruction. The programmer may use these character- 
positions for storage of any information he desires. 

A signal, set within the Processor, to indicate that the 
programmer has written certain Instructions improperly, 
and an incorrect or meaningless result has been obtained. 
When the Overflow Alarm has been set, the Processor will 
halt before executing the next Instruction, unless that 
next Instruction is the TEST OVERFLOW variation of TEST. 

An auxiliary cell, not part of the memory proper, used 
by the Processor in carrying out its operations. 

These terms, borrowed from the printing trade, describe 
the placement of information within a field or a regis- 
ter so that the right-most or left-most character of 
the information occupies the right-most or left-most 
character-position of the field or register. This 
operation DOES NOT involve dropping non-significant 
zeros. As the terms "right- justified" and "left- 
justified" are defined here, non-significant zeros are 
considered to be part of the information . 

Whenever, in this Ifenual, it is stated that the Contents 
of a field are transferred right-justified or left- 
justified to a register, it must be understood that the 
register is first "cleared" by placing zeros in eqich 
character-position. 

Whenever it is stated that the contents of a register 
are transferred right- justified or left-justified to a 
field, it must be understood that only as many characters 
are transferred as the field can contain. The remaining 
characters in the register are not transferred. 

It must be clearly understood that all registers men- 
tioned in this Manual have been "invented" by the. authors as aids to clarity 
and conciseness in describing operations. 

These registers are entirely fictitious, and bear only 
coincidental resemblance (if any) to the registers actually present in the 
Model 304 Processor. 
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EXEGUTIOM TIMES OF^ INTERNAL OPERATIONS 

The basic imit of time within the Processor is a Cycle of 60 micro-seconds 
(60 ots = 0,000060 seconds). For convenience, this xinit is ref^n^ed to as 
1 micro-minute (lumin = 0.000001 minute). 

Execution times in this table are expressed in micro-minutes. To convert 
total micro-minutes into minutes, move the decimal point six places to 
the left. 



Operation 


T3 


^•^ 


' 


Jump 


Additional 


•H 




-V 


-V 


+v 




(^ 


M!=> 










1 Add 


10 


1 


2 






+ 1 if signs different! TaND result 
+ 1 if signs alike J f negative 
+ S\m of the digits of IB] 


2 Subtract 


10 


1 


2 






3 Multiply 


26 


1 


2 






4 Divide RJ 


14 


1 


2 




\ 


h Sum of the Quotient digits 
^+2 per Quotient digit 


5 Divide LJ 


15 


1 


2 




] 


\j«- 2 J average to round Quotient 


6 Modify Add 


10 


1 


2 


~ 






7 Modify Subtract 


10 


1 


2 








8 Extract 


10 


1 


2 








9 Insert 


14 


1 


2 








D Add Binary 


10 


1 


2 








A. Complement Binary 


10 


1 


2 








A Test Bit 


9 


1 










B Com-pare Numeric 


9 


1 








- 1 if signs are different AND 
neither number is zero 


G Compare Alpha 


9 


1 










P Compare Equality 


9 


1 




1 


1 


+ 1 if Ca] greater than [A] 


E Count 


11 


1 








+ 1 if Ci3 greater than [T] , or if 
■ .' no jump 


P Test 


5 


1 










H Combine 


12 


1 


2 








J Distribute 


11 


1 


2 






+ 1 for sign spli toff variation 


K Suppress 


15 


1 


2 






+ 1 for sign splitof f variation 


L Edit 


13 


1 


2 








M Merge, Runout 


19 


2 


2 






See Instruction Description 


Cutoff 


22 


2 








See Instruction Description 


N Move 


B 


1 


1 






-^ 2N +(2 per full 100 words) 


Cf Pack 


7 


1 




1 




+13N +(1 per full 100 triples) 


P Unpack 


7 


1 


1 






+13N +(1 per full 100 pairs) 


Q Sift, single key 


15 


1 


2 






+ 4 per item compared -with sieve 
+ 2 if AF teiroination 


double key 


16 


1 


2 






+ 5 per item compared with sieve 
+ 2 if AF termination 


R Summarize 


14 


1 




1 


1 


+ 4N +( number of intermediate 
negative results) 


Branches wiTHqur executions 














All Tape Instructions 


11 












PRINT 


9 













AUTOMONITOR: 



Add 12 micro-minutes between termination of the Instruction to 
be monitored, and execution of the fii^t Instruction in the 
Monitoring Program. This time is used for storage of information 
in ^01 through ^04. 

1^-3 



EXECUTION TIMES OF EXTERNAL OPERATIONS 



These operations are usually timed separately, and for this purpose, the milli-second 
( 0.001 second) is the most convenient unit* Times in this table are expressed in 
Mlli-^seconds, and include execution time of each Instruction "within the Processor, 
and all acceleration and repositioning times. 

To convert total milli-seconds into minutes, divide by 6 and move the decimal point 
four places to the left. 





O -H 
to 6-< 
(0 








<D -a 

O 0) 




PROCESSOR Free - 


Operation 


g.3 


PROCESSOR Variable Time 


PRINTER or CONTROLLER busy 


WRITE MAGNETIC TAPE 


8 


4 per word written 


13 


RblAD MAGNETIC TAPE 


4 


4 per word read® 


9© 


INDEX FORWARD 


4 


4 per word indexed over 


9 


INDEX BACKWARD 


^60 


4 per word indexed over 


50 


WRITE^GGPY 


8| 


4 per word written by 
the WRITE portion 


24 + 4 per word copied 


COPY 


0li 




31+4 per word copied 


SEARCH 


14 




20 + 4 per word searched over 


WRITE -COPY-READ 


(DSi 


4 per word written 
+ 4 per word copied 
+ 4 per word read 


20 


COPY-READ 


® 8i 


i per word copied 
+ J per word read 


20 








SEARCH-READ 


^ki 


4 per word searched over 
+ 4 P®^ word read 


9 


HhlWIND 


1 






PRINT 


3 


' ■ 


100 + 14 per blank line after 
the printed line . 


PUNCH PAPER TAPE 


2 


17 per character punched 




TYPE ON CONSOLE 


4 


150 per character typed 




PUNCH ON CONSOLE 


4 


100 per character punched 




READ PAPER TAPE 


74 


0.77 per character read® 




READ CARDS 


44 


60 per card read 





NOTES: (D If Destination Tape in this operation was just JDreviously used as Source 
Tape for READ, INDEX FORWARD, INDEX BACKWARD, SEARCH or COPY, add l6ms to 
Processor fixed time. 

©If READ terminates because memory-allocation has been exceeded, increase 
the time in both columns by Jms per word for average record-length in the 
file. 

©If INDEX BACKWARD follows use as a Destination Tape, add 4ms to Processor 
fixed time. 

Control characters, such as "Putaway** and "Compute Code" must be coimted 
as characters. 
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SPECIFICATIONS on which execution-times of external operations are based: 



MAGNETIC TAPES: 



Acceleration 3 nis 

Deceleration 3 nis 

Data Transfer 20,000 characters per second 

Data Recorded 200 characters per inch 

Tape Movement 100 inches per second 

Rewind 2.2 minutes per full reel 



PRINTER: 



Printing Speed 600 lines per minute 

Blank Lines 4,200 lines per minute, regardless 

of how many, or how few, lines 
are to be left blank 



PAPER TAPE PUNCH: 



Punching Speed 60 characters per second 



CONSOLE TYPEWRITER: 



Typing Speed about 6j characters per second 
Punching Speed 10 characters per second 



PAPER TAPE READER: 



Reading Speed 1,300 characters per second 



PUNCHED CARD READER: Reading Speed 1,000 cards per minute 
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The f©ll©wiiig list gives the Operatiom G©des, 0perati©n Hames, and Standard 
AfebreTiatit^Bs f®r all Operati©as in the lational 304 lata Processor. 



6 
? 

a 

9 

D 

A 

A 
B 

B 

E 



Subtract 
Mmltiply 

Round 
BiTide Eigkt-Jmstlfied 

Romnd 
l)if:ide Lef t-^mstified 



Modify Smbtra©t 
Extraet 
Insert 
Add Binarj 
Modml© 64 
Complement Binaiy 
Test Bit ■ 
Compare Humeric 
Compare Alphan*amerie 
Compare Eqmality 



Overflow 
^ptio® Switafe 
Reader Code 

Pmnefe Code 



H 

J Distribute . 

Sign Split-off 

K Smppress . 

Sign Split«-®f f 
L Edit 

Gheek-Proteetion 
M Merge 

Cmtoff ,;:' 

Rwiomt 
M M@ve 
Pack 
P Unpack 
Q Sift 
H SiHimarisae 



ABB 5 

SWBs 
MLTt 
MOLTsR 

BEJ? 

DRJsE 

BLJg 
HABBg 
MSBBs 

EXTg 

SERfs 

BIIA? 

BBJAgM 

BIIGs 

TBITs 

ON? 

Qkt 

Gil 

GITs 

mSTsd 

TlSTgS 

TESTsR 

TESftP 

G6MBS 

DISTs 

DISTsS 

SUPPs 

SUPPsS 

EDITg 

EDIfgP 

MEGEgC 
MRGEgR 

m!mt 

PAGEg 
UPKg 
SIFTg 
SUMMs 



s 


ReTd.md Magnetic Tape 






Somree Tape 


wmBgs 




Bestination Tape 


WIKBgB 




Use LoGkomt, Somree 


LefCKgS 




Use Loekomtj Bestination 


L€lCK8B 


T 


Read Magnetic Tape 






Complete Records 


REABg 




Partial Records 


REABgP 




Test Branch Conditions 


REABgT 




Index Forward 


USBXgF 




Index Backward 


IlBXgB 


I 


Write-Gopj 


WCg 


¥ 


Write-Copy-Read 


WCgR 


B 


Oopy 


C0PY2 


V 


Copy-Read 


cefPigR 


¥ 


Write Magnetic Tape 






Fixed-Length Records 


WTsF 




Variable-Length Records 


WTif 




Test Branch Conditions 


IfTsT 


¥ 


Write Tape and Erase to End 






Fixed-Length Records 


>WTKgF 




Variable-Length Records 


WTKsV 


X 


Print 


PRMTg 


I 


Type-Pimch 






Console Typewriter 


TIPEg 




(variations thru 5) 






High-Speed Pimeh 






Fixed Foiroat 


PPTgF 




Programmed Format 


PPTgP 


z 


Read Paper Tape 


RPTs 


z 


Halt 


HALTS 


« 


Read Cards 


RCBg 
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TABLE IV-1: 



Language Code 



ZONE 
BITS 



NUMERIC 
VALUE OF 
ZONE BITS 



NUMERIC BITS 
0000 0001 0010 0011 0100 0101 Olio 0111 1000 1001 1010 1011 1100 1101 1110 nil 



00 
01 
10 

11 



6 

a 



23456789(s>^ space & • ' 

BCDEFGHIDAmnep 

JKLMN9PQR %£$()/ 



1 

- A 

+ 

* # S T 



U V W X Y Z 



s u 



w X 



TABLE IV-2: Modification of first word of Instruction by Index Register 



S-value 
4 
2 
1 



A syllable modified 
B syllable modified 
C syllable modified 



S-values of syllables 



Sum Determines combination 

of syllables modified. 



4 

J L 



2 

J L. 



If S = O, no Index Register is used, and R is irrelevant. 



TABLE IV-3: Interchange of syllables in »00 



(000) before operation 



mm 




P 

1 1 


,Q, 


mm 


^ i I ii 



(000) after operation 



positive 
negative 





. ».... 


" '■. 


P 

1 1 


Q.®. 


2 


. 


....4 














\. ."ft... 


...JC: 


Qe 


2 


P 



ADD 

The respective contents of the A-field and the 1-field 
are right- justified, and added. The resmlt is stored, right- 
justified, in the G-field. 

OVERFLQW : ALARK ; Will be set if the sua exceeds the capacity of 
the e-field. 
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INSTRUCTIOxV FORMAT: 



9 


s 


7 


6 


5 4 

1 


3 


2 


1 
I 1 1 


OP 


. A. 


. B. 


^.^ 




V 


M 


S 


R 


Al Ar 
_ 1 


Bl Br 
1 


Cl Cr 



Operation! ADD (ADD) 
Operation Code: 1 



DEFINITIONS: 

Op: operation code. 

M: auto-monitor level: 0, 1, 2, 3. 

S: designates syllables for modification 
by index-register OOR. 

R: designates OOR as index«register. 

A: base of address of addend. 

Al, Ar: locations of left-most and right-most 
digits, respectively, of the addend, 

B: base of address of augend. 

Bl, Br: locations of left-most and right-most 
digits, respectively, of the augend. 

C: base of address in which sum is to be stored,' 

Cl, Cr : locations of left-most and right-most digits, 
respectively, of field allocated to the sum, 

V: variation designator; 

only the sign of V is relevant. 
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DESCRIPTION OFr ADD 

This is a right- justified operation, 

[A] + [b] — > [C] 

[a] is transferred, right-Justified, to a lO-character-long 
working register (Ra) . [b| is transferred, right-jmstified, to another 
10-character-long working register (Rb) . 

In the course of both these transfers, the zone-bits of all 
the characters transferred are replaced by 0-bit s. 

With clTie regard to the algebraic signs of [A] and iB] , as 
stored in Al and Bl, the contents of registers Ra and Rb are added, and 
the sum is stored in a third working register (Re), 11 characters-longo 

The contents of Re then replace (cj , right- justified. The 
correct algebraic sign of the sum is then inserted into the sign-bit 
position of character Gl . 



OVERFLOW ALARM; Will be set if some character (other than "zero") is 
not transferred from Re to fc] . 



MOTE I (Re) will equal Negative Zero only if DO equals Negative Zero 
and LBlI equals Negative Zero, 
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Examples - ADD 



Example 1 - Add a positive number to a positive number . 



9 


8 7 6 

1 1 


5 4 3 2 10 

1 1 1 1 1 1 


1 


2 5 4.6.2 A. 3. 6 








5.3 2.0 9.6 



98 76543210 
i^!i;ll;i;ll4.3.71;iii;l;;l:l Cell 250 



mmmmmmm9,3.k\ ^^^-^ ^^2 



.^ Register Ra 



18. 2.6.7 .O.0. 4.2. 3. 51 Cell A36 before 



sign 
9 a 7 6 5 4 3 2 1 

__l I I ! 1 1 1 J 1 1 /""N 

0.0.0.0.0.0.0.4.3.71 {*J 



^ Register Rb jQ .0.0 .0.0 .0 .07931:1 (+) 



1.3. 7. immm^mm Cell A36 after ^ Register Re |0.0 .0.0 .0.0 .0 .1 .3.7 .11 (£) 



Example 2 ~ Add a positive number to a negative ntonber . Result is a positive number . 



98765432 10 


1 


3 4 5 


7.8 4 7 7.7 








8.4 7.2 7.0 



9876543210 
;i;:i-.3.5.2.3l;i»ii;;il Cell 345 - 



9 8 7 6 5 4 3 2 10 

J — 1— _j — I — I — 1 t « ■ 



^ Register Ra |0 .0.0 .0.0 .0 .3 .5 .2 .3 



sign 





:iM8.7.9.4.2.0(ii;ii| Cell 784 , ^ Register Rb |0 .6.0 .0.8 .7 .9 A .^ 0| (J^ 



6.7.4 .8. 6. 9. 3. 3.4.61 Cell 777 before 



WHO .0.8 .7 .5 .8 .9 .7 1 Cell 777 after ^ . Register Re 10.0.0.0.0.8.7.5.^.9.7! (r) 



IV-1-4 



Examples - ADD 



Example 3 - Add a negative number to a positive number . Sign of negative result 
combined with left-most character. 



9 


8 7 6 

1 1 


5 4 3 2 10 

II II 


1 


h 5 


2.6 5 0,2 








3,1 9,0 9.0 



9876543210 

mmmmmm^j^.sM ^^n 450 



9876543210 

J I I I I I I I L 



sign 



*^ Register Ra lojojo jojo '.0 'ojs !4!5l (^ 



W.V.N.E.5.-.-^■7.^>^#l ^^^^-^ 260 ^ Register Rb 1 6.5. 5 .5.5 .0.0.7.0.11 Q 



7.6.8.3.5.0.1.4.4.41 Cell 502 before 



F. 5.5. 5.5. 0.0. 4. 5. 61 Cell 502 after ^ Register Re |0 6.5.5 .5.5 .0 .0.4.5 ."^ (^ 



Example 4 - Add two negative numbers . Set overflow alarm . 



98765432 10 


12 5 


6.6 6 6.8.6 





2.0 4.113.0 



9876543210 

mmmmm mij:s:9] ceii 250 



mmmmM}i.7T:wm ceii 666 



Register Ra 



4 . 5 . 6.9.0 . 0,2 .5.3,31 ^^^^ ^^^ ^^^^^^ 



sign 
9 8 7 6 5 4 3 2 10 

JO.O.O.O.O.Q^ygll Q 



- Register Rb 10.0:0.0.0.0.8^7:^73) Q 



m^im^MjTiTf] Cell 686 after ^ Register Re |0. 0.0. 0.0. .1 .8 .7.7 .71 Q 

Overflow alarm will be set 



IV-1-5 



TABLE IV-1: Language Code 



ZONE 
BITS 



NUMERIC 
VALUE OF 
ZONE BITS 



NUMERIC BITS 
0000 0001 0010 0011 0100 0101 0110 0111 1000 1001 1010 1011 1100 1101 1110 nil 



00 
01 
10 

11 



Q 

1 
a 
a 



1 
- A 

+ 



2 3 45 67 89(0)0 space & • ' 
BCDEFGHIDAmnep 

( ) / 



JKLMNO'PQR%£$ 



#STUVWXYZ 



u 



W X 



TABLE I V-2: Modification of first word of Instruction by Index Register 



S-value 
4 
2 
1 



A syllable modified 
B syllable modified 
C syllable modified 



S-values of syllables 



Sum Determines combination 

of syllables modified. 



4 

J L 



2 
J I- 



1 

J L 



If S — O, no Index Register is used, and R is irrelevant. 



TABLE IV-3: Interchange of syllables in «00 



(000) before operation 



I. i .♦ I d 



Q 



V 


($00) after operation 


positive 
negative 




-™ 


?""■"""""" " '^ 


P 


f\ (X\ O 






■■*■-■ 4- -" 


IT 

1 J 


H®. 2 






Q e 2 


P 




t— _j 


^.. )...M,Mi : 


« ' 





SM B T R A C T 

The respective contents of the A-field and the 
B-field are right -justified, and the difference, M - M is 
generated. The difference is stored, right- jmstified, in the 
C-pmtaway field. 

OfERFLOW ALARM ; Will be set if the siim exceeds the capacity 
©f the G-field. 



3J-2-1 



INSTRUCTION FORMAT: 



9 


8 


7 


6 


5 4 

• 


3 

L 


2 


1 

L 1 i 


Op 


A 
1 1 


B 
1 1 


C 
1 • 




V 


M 


S 


R 


Al Ar 
1 


Bl Br 

1 


Cl Cr 



Operation: SUBTRACT (SUB) 
Operation Code: 2 



DEFINITIONS: 

Op I operation code. 

M: auto-monitor level: 0, 1, 2, 3. 

S: designates syllables for modification 
by index- register OOR. 

R: designates OOR as index register. 

A: base of address of minuend. 

Al, Ar: locations of left-most and right-most 
digits, respectively, of the minuend. 

B: base of address of subtrahend. 

Bl, Br: locations of left-most and right-most 

digits, respectively, of the subtrahend. 

C: base of address in which difference is to be stored, 

Cl , Cr: locations of left-most and right-most digits, 

respectively, of field allocated to the difference. 

V: variation designator; 

only the sign of V is relevant. 



IV-2-2 



DESCRIPTION OFs SBITRAGT 

This is a right- jmstified o|)eara.ti©n. 

M - tB] -V CGI 

CAD is transfeiTed, right-jmstified, to a lO-character-lomg 
workiijg register (Ra), [¥] is transferred, rigfet-jmstified^ to amotker 
lO-cfearacter-long working register (Rb), 

In the course of both these transfers, the zone-bits of all 
the characters ' transferred are replaced by 0-bits. 

The .algebraic sign of CB]] is then considered to be the opposite 
of the sign stored in Bt. 

With dme regard to the sign of ZA2, as stored in At, arid the 
changed sign of tM2, the contents of registers la and Rb are added ^ and 
the sum is stored in a third working register (Re), 11-characters long. 

The contents of Re then replace Q3, right- jmstified. The 
correct algebraic sign of the result is then inserted into the sign-bit 
position of character Ct ♦ . 

OVERFLOW ALARM ; Will be set if some character (other than "zero'*) is 
not transferred from Re to [02 , 

NOTE: (Rc) will equal Negative Zero only if CAJ equals Negative Zero 
and [HD equals Positive Zero. 



IV-2-3 



Examples - SUBTRACT 



Example 1 - Subtract a positive number from a positive number . 



9 S 7 6 

I. 1 


5 4 3 2 10 

,11 II 


2 2 4 5 


5.0 6 0.0 





6.3 7.4 8.1 



9 8 7 6 5 4 3 2 10 

mmms:7,L,o '^sm ceii 245 



mm's.'i.7.om^m^ ^^^^ ^°^ 



|D,4.5.3.3.7.2.2.4.Z1 Cell 600 before 



sign 



9 8 7 6 5 4 3 2 10 

Register Ra |o'.o'o'.o!o '.o!8'.7!4!ol (^ 



Register Rb lO.Q.O .0.0 .0.5 .5 .7 .0| (^ 



(sign changed) 



:i;J0.0.0.0.3.1.7.0(^;i| Cell 600 after ^,_,_^ Register Re |0 0.0.0.0.0 .0.3.1.7 .O] (J^ 



Example 2 -• Subtract a negative ntimber from a positive number . 



9876543210 



t I— —i i_ 



4 3 4 5.6 5 6.5.6 



010 10 15. 4 18, 6 18 .6 



9 8 7 6 5 4 3 2 10 

iiiil3,3iiiiiiil ^^^^ ^34 



MF .2 .emmmmmm ^^^^ ^^^ 



L.5.7.3.0.0.0':o:o'J] Cell 656 before 



9 8 7 6 5 4 3 2 10 

^ Register Ra lo'.o'.ojo'o '.o'o'.0*3'3i C^ 

I 1 L 1 1 1 i^f^ ^ \^ \ \ J 



X^TIZ^^) l " . o.".o . o . o ,o^,.,6fQ 



M(:> ^ ."^WmmmM M Cell 656 after .,_. — Register Re (o. 0.0.0 .0.0 .0.0 .6.5 .91 (7\ 



IV-2-4 



TABLE IV-1: 



Language Code 



ZONE 
BITS 


NUMERIC 
VALUE OF 
ZONE BITS 


0000 


0001 


0010 


0011 


0100 


0101 


NUMERIC BITS 
0110 0111 1000 1001 


1010 


1011 


1100 


1101 


1110 


nil 


GO 


111 


III 





1 


2 


3 


4 


5 


6 7 8 9 


@ 


^ 


SPACE 


& 


• 


1 


01 


III 




— 


A 


B 


C 


D 


E 


F G H 1 


D 


A 


m 


n 





P 


10 
11 


III 


ill 


+ 


J 
# 


K 
S 


L 

T 


M 
U 


N 
V 


9 P Q R 
W X Y Z 


% 
d 


£ 
s 


$ 

u 


( 


) 

w 


/ 

X 


iiiiiiiii 





TABLE IV-2: Modification of first word of Instruction by Index Register 



S-value 
4 
2 
1 



A syllable modified 
B syllable modified 
C syllable modified 



S-values of syllables 



Sum Determines combination 

of syllables modified. 



4 

J L 



2 



1 
J L 



If 8 = 0, no Index Register is used, and R is irrelevant. 



TABLE IV-3: Interchange of syllables in «00 



(«00) before operation 







p 

1 1 


,Q, 


; 


I J r,: 



(0OO) after operation 



positive 
negative 





' •» - 


p 


Q ® 2 





"■■'"■■i * 


Q e 2 


p 



MULTIPLY 

The respective contents of the A-field and the 
B-field are left- justified and multiplied . The G-putaway is 
left- justified, and consists of as many digits as the G-field 
•vdll accommodate. The next 10 digits of the product (from 
left to right) are then put away in cell @G0, with the albegraic 
sign of the product . 

There are two variations of this Instruction: 

'* Iormal variation " in T^ich the Instruction operates 
as just described. 

" Rounded variation '? in which the G-putaway is rounded 
at digit position Gr , The next 10 digits are still stored in 

mo. 

The Instruction has the restriction that the A-field 
may not contain more than 9 digits. 

OVERFLOW ALAEM : Will be set if the A-field contains more than 
9 digits. Note also that rounding may cause overflow, and set 
the Overflow Alani. 



If-3-1 



INSTRUCTION FORiMAT: 

98765432 10 



Op 


—J — . — , 


1 1 


1 1 




V 


M S' 


R 


Al Ar 


Bl Br 
1 


Ct Cr 

t 



Operations MULTIPLY (MJLf) 
Operation Code: 3 



DEFINITIONS: 

Ops operation code, 

M: auto-monitor level: 0, 1, 2, 3. 

S: designates syllables for modification 
by index-register OOR, 

R: designates OOR as index register. 

A: base of address of multiplicand. 

Al, Ar: locations of left-most and right-most digits, 
respectively, of multiplicand. 

B: base of address of multiplier, 

Bl, Br: locations of left-most and right-most digits, 
respectively, of multiplier. 

C: base of address in which product is to be 
stored, 

Cl, Or: locations of left-most and right-most digits, 
respectively, of field allocated to the 
product . 



V: variation designator: 



V 







Specifies 



Unrounded product 



1 I Product rounded at Or, 



AJsbreviatioa 



Next 10 digits -> @00: 90 
with sign of product. 



HULT 



MULfsl 



IV-3-2 



DESCRIPTION OF: MULTIPLY 



This is a left-justified operation. 

CAH X LbH -^ — ^ CCD and into @00j90. Both pmtaways with sign. 

Ldis transferred, left- justified, to a lO-eharacter-long work- 
ing register (Ra)| LB] is transferred, left-justified, to another 
lO-character-long working register (Rb) . In the course of both these 
transfers, the zone-bits of all characters transferred are replaced by 
O-bits. 

The contents of Ra are then multiplied by the contents of Rb, 
and the 20-charaGter-long product is generated in a third working register, 
20-characters long (Re). Note that the product of two lO-digit numbers is 
always 20 digits long, 

V = : The contents of Re are transferred, left- justified, to EG , for 
as many digits as exhaust the capacity of ECl. The next 10 digits, count- 
ing from left to right, are then transferred to @00; 90 . Any additional 
non-zero digits of the product are lost. 

¥ = I s The pmtaway in this variation is the same as that in J - O -a- 
except that the portion of the product transferred to £g2 is rounded in 
digit-position Gr?s that is, if the digit in position 9 ©f §00 is a "5" 
or greater, then UQ is augmented by '^l" . 

If the algebraic signs of the two operands are alike (as indi- 
cated by the sign-bits of At and Bl) then the sign of the product is 
positive I a 0-bit is inserted into the sign-bit position of digit Cl , and 
into the sign-bit position of the digit in position 9 of ' @00 . 

If the algebraic signs of the two operands are unlike , then the 
sign of the product is negative | a 1-bit is inserted as the sign-bit of 
CL , and as the sign-bit of digit-position 9 ©f ©00. 

Decimal Point ; The number of digits to the left of the decimal point in 
the product is equal to the sum of the number of digits to the 'ai ; f3^: 
the left of the decimal point in each of the factors. Thus? 

2.000000000 (Ra) 

X 3.000000000 IeW 



©6.000000000000000000 (Re) 

RESTRICTION S [A] may not be more than 9 digits long. Otherwise, the 
product will be invalid, and the Overflow Alarm will be set. 

OVERFLOW ALARM ; Mill not be set if some non-zero character is not trans- 
ferred from Re to @00 . 

Will be set if the above restriction is violated. 

Rounding may cause a carry to be generated out of Gl | if 
so, the Overflow Ala.rm ^11 be set. The carry will be lost. 
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Examples - MULTIPLY 



Example I t V=0 



CaI and LbH both are positive numbers 



1.4.2 3.7.9l5>;3 



qIqIoI7'.3|2.i|6.0 



sign 



9^76543210 9B76543210 

mmiM,h.2.immM Cell Va ^ Register Ra 1 1.4.6.2.1 .0 ,0 .0.0 ,0 | Qj 

X 
Wm^^^^MTJW Cell 379 ^ Register Rb |3, 5,0,0 ,0 .0 .0 .0 .0 ,0 | (£) 



Register Re 0. 5.1.1.7.3 5.0.0 0. 0, 0.0.0.0 ,0 .0 .0 .0 .0 



B. 7. 4. 9 .6. 3. 2 .8.4.3 
Cell 563 before 



^^ 



li iiijo, 5, 1 .1 -7.3.5 1 



Cell 563 after 



J L 



7 4.3,2.8.6.4.1.0.5 
Cell @00 before 



O.O.O.O.O.O.O.O.O.Ol 



Cell @00 after 



o 
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Examples - MULTIPLY 

Example 2 ; Y-1 

Sign of CAJ Is positive 
Sign of CbJ is negative 
Putaway in QC] is rounded at Cr 



9:i;3u:8:5 



o? 







B.lWiW.O 



987 65 4 3210 
l!;m.2.1^^.6.ZtX3Ti Cell 427 



sign 



9 876543210 
Register Ra 14.2.1 .5.6 .4.9 .3 .OOl Q 



Wmm 1.0. 5mmmm Cell 913 > Register Rb 17.1.0.5.0,0.0 .0.0 .0| Q 



Register Ro |2. 9.9 .5 .2 .1 .8 .8 .2 .7.6 . 5.0.0.0 0.00 ol (T) 

I . — — n..,.,. .,, ..,.,1 V-^ 



E.9.3.2.5.6.AX9:il 
Cell 685 before 



Cell 685 after 
multiplication, before 
ro\inding 



liiiii lB . 9 . 9 .^111 



Cell 685 after rounding, 
and insertion of sign 



1^.4.0,5.7.0.2.9.4 ,81 
Cell @00 before 



18.8.2.7.6 5 oToTol 

Cell @00 after 
multiplication 



P.$i:? .7.6.5.0.0.Q;0 



Cell @00 after 
insertion of sign 



IV-.3-5 



Examples - MULTIPLY 

Example 3 * V=l 

Illustration of how rounding can set Overflow Alarm 



1.0.9 



3.1,2|l,a.O 



OlOlO 



5 . 2 1 7,^10 , 



987 6 5 43210 9 876543 2 1 

JiiiliM 9.8.0.0 lilil Cell 109 ^ Register Ra I? , 8 . .0.0. . 0,0.0.0 . 1 



WM9 .7 .6m^M^M Cell 312 — ^Register Rb 19.7,6,0,0,0.0,0,0,0 



Register Re 19.5.6.4.8.0.0.0.0,0.0.0.0.0.0.0.0.0.0.0 



H 2.2.2.9.6.5.4.7.3 



Cell 180 before 



lp;i;li;;i;»^^^^ 



Cell 180 after 
multiplication, before 
rounding 



iiiiiililiiiiiio 



4. 3.0. 6.7.4. 2. 0.4.8 
Cell @00 before 



5.6.4.8.0 0.0.0.0 
Cell @00 after 



Cell 180 after rounding 

The OVERFLOW ALARM will be set 
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TABLE IV-1: Language Code 





NUMERIC 














NUMERIC BITS 
















ZONE 


VALUE OF 






























BITS 


ZONE BITS 


0000 


0001 


0010 


0011 


0100 


0101 


0110 0111 1000 


1001 


1010 


1011 


*1100 


1101 


1110 


nil 


00 


iill 





1 


2 


3 


4 


5 


6 7 8 


9 


@ 





SPACE 


& 


• 


1 


01 


Hill 


— 


A 


B 


C 


D 


E 


F G H 


1 


D 


A 


m 


n 





P 


10 


■■III 


+ 


J 


K 


L 


M 


N 


OP Q 


R 


% 


£ 


$ 


( 


) 


/ 


11 


III 


* 


# 


S 


T 


U 


V 


W X Y 


Z 


d 


s 


u 


Y 


w 


X 



TABLE IV-2: Modification of first word of Instruction by Index Register 



S-value 
4 
2 
1 



A syllable modified 
B syllable modified 
C syllable modified 



S-values of syllables 



Sum Determines combination 

of syllables modified. 



2 

J L. 



1 
J L 



If S = O, no Index Register is used, and R is irrelevant. 



TABLE IV-3: Interchange of syUables in ^0 



(^00) before operation 



* » 'i ■ 



JL 



((fOO) after operation 



positive, 
negative 





..1 ...jl 


P 


Q ® 2 








^. "nln.M.r.tj 


Q e 2 
1 i 


p 



DIVIDE R I G H T ~ J U S T; I F I E D 

The respective contents of the A-field ajid the B-fipld 

[0] ' 

are right- justified, the qmotient is generated as though 

LA] 
CAH and CbH were integers, and the quotient is stored, right- 
justified, in the C-^ield. 

In one variation, the remainder is stored, right- 
justified, in cell @00, -with the algebraic sign of LEQ. 

In the other variation, the quotient Is rounded at 
the right-most digit position of the C-field, and no pitawaj 
is made to @00. 

The Instruction has the restriction that the A-fleld 
may not contain more than 9 digits. 

OVERFLOW ALARM ; Will be set if the A-field contains more than 
9 digits, or if an attempt is made to divide by zero. Note 
also that rounding can cause overflow, and set the Overflow 
Alarm, 

Will be set if the result exceeds the capacity 
of the C-field* 



IV-4-1 



INSTRUCTION FORMAT: 

9 S 7 6 5 4 3 a 1 

t I I, >„., !..„ 



Op 



B 

J L, 



Operation- DIVIDE, RIGHT -JUSTIFIED (DRJ) 
Operation Code; 4 



V 



M 



R 



Al Ar 

t. .■■.., 



Bl Br 

» 



Cl Cr 



DEFINITIONS: 

Op: operation code. 

M: auto-monitor level: 0, 1, 2, 3. 

S: designates syllables for modification 
hj index-register OOR. 

R: designates OOR as index register, 

A: base of address of divisor. 

Al, Ar: locations of left-most and right-most 
digits, respectively, of the divisor. 

B: base of address of dividend, 

Bi, Br: locations of left-most and right-most 
digits, respectively, of the dividend. 

C: base of address in which quotient is 
to be stored. 

Cl, Cr: locations of left-most and right-most 
digits, respectively, of field 
allocated to the quotient. 

V: variation designator: 



NOTE: If quotient is 
unrounded, remainder is 
stored in @00:90 with 
the algebr^TTiign of LBl; 
putaway is right- justified. 



V 


Specifies 


Abbreviation 





Quotient unrounded 


DRJ 


1 


Quotient rounded at Cr 


DEJ:E 



IV-4-2 



DESGRIPTIOH OF: DIVIDE RIGHT-JUSTIFIED 

This is a right- justified operation. 



[A] 



■^[(I\f wiromided, remainder - — ^ @00! 90 



or - — =— ^[CJ, rounded. 

CA3 

CAI is r transferred,* right- justified 5 to a 10-character-long 
working register (Ra)'.' [W] is transferred, right-justified, to another 
10-character-long worl^ng register (Rb) . Jn the course of both these 
transfers, the zone-bits of all characters transferred are replaced bj 
0-bits. 

The diTision is performed, generating the same number of digits 
of the quotient as the number of digits spejjified by the size of €b2. 
The quotient appears, right- justified, in a third lO-character-long work- 
ing register (Re), with the remainder being held in Rb. 

The contents of Re then replace CcG , right- justified^ 

T « O g - The contents of Rb (the remainder) replace the contents of 
@00s90, and the sign-bit of the character in position Bt (i«e,-the sign 
of the di-rldend) is copied into the sign-bit position of character- 
position 9 of §00, so that the remainder has the same algebraic sign as ^B' 

f ^ I t The division is resumed, to generate one more digit of the 
quotient. If that digit is a "5" or greater, then £Q2 is augmented by *'l" 
No putawaj is made to @00, in this variation. 

If the algebraic signs of the two Operands are alike ^ (as in- 
dicated by the sign-bits of the digits in positions At and BL);then the 
sign ©f the .quotient is positivej a 0-bit is inserted into the sign-bit 
position of Cl , If the algebraic signs of the two operands are unlike ^ 
then the sign of the quotient is negative | a 1-bit is inserted as the 
sign-bit of Qi . 

RSSTRICTIOIS g 1) An attempt to divide by zero will set the Overflow 
Alarm, and no divt^^on will take place « 

2) [A] may not be more than 9 digits long, Otherwise, 
the Overflow Alarm will be set and the quotient will be invalid, 

QfERFLOW ALARMS Will be set if restrictions 1 or 2 are violated. 

¥13,1 be set if some character (other than "zero") is not 

transferred from Re t© TO • 

fomidli^g, my caBse a carry to be generated out of Cl; 
if so, the Overflow Alarm will be seto The carry will be lost. 
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Example - DIVIDE RIGHT-JUSTIFIED 



Example 1 - DJTide a positive number by a positive nximber and save the remainder . V=0 



9 


8 7 6 


5 4 3 2 10 

II II 


4 


7 3 5 


2.9 6 4 3.2 





Oj 


9.8 9.3 7.1 






■^'LC: 



9 8 7 6 5 4 3 2 10 

iMMi^mm^mM ceii 735 



987654 32 1 

.Register Ra lo '.o'.O !o'q '.0 Jq'.o'.I aI 



2.5.7.3.2.0.9mmM Cell 296 —> Register Rb 10 .0.0 .2 .5 .7 .3.2 .0 .9 



sign 


o 



Quotient 



Register Re 

iiiiiil o.i.8.3 Ao T o 



: AFTER DIVISION: 



9 7 6 4 1 .0.5.2.2.8 



,Cell 432 before 



V 



S;:i;:ilo.i,8.3,8,a.o[ilJ 

Qell 432 after 



.Remainder 
Register Rb 



0.0.0.0.0 ,0,0..0.0.9 



6.7.3.6.8.1.2T51T2 
Cell @00 before 



Sk- 



0000000009 
II — I — -J- — I — 1—4 — I 1-4. 

Cell ©00 after 
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Example - DIVIDE RIGHT-JUSTIFIED 



Example 2 - Divide a TX)3itlve number by a negative number and round . V = 1 
Putavray to cause overflow . 



9 


8 7 6 

1 1 


5 4 3 2 10 
II II 


h 


5 3 5 


1.1 1 2 0,1 


1 





7.5 8.3 2.0 






>ccj 



98765432 10 



i[2.i.3.7.4."g1iiiiii} ^^^-'-^ ^^^ 



Register Ra 



sign 
9^76543 2 10 

'III 1111 i__j /"^ s. 

2 3 ( - ) 



Register Rb | , , , , 2 , 1 , 3 ,7 ,4 ,6 1 Q 



e^.F.F.sp.0.1.4.0.2.51 Cell . 201 before 



^mm^^mm^Z ,^ 3\ ^ 201 after ^ Register Re iiJigiilili-liO .0 .9.2 .9 .3 I Q 

division, before • V-x 



division, before • 

rounding . 
Overflow Alarm set 



!;aj;;iii»^iglp Cell 201 after .„_ Additional digit of quotient. 

rounding, and 
insertion of sign. 
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Example - DIVIDE RIGHT-JUSTIFIED 



Example 3 - Divide a positive number by a positive number and round . V - 1 



9 8 7 6 

f ' ' 


5 4 3 2 10 

1 II 1 1 


k 


2 5 


3.6 0,L 6.0 


1 





8.7 7.3 7.3 



CA3 



> tea 



9 8 7 6 5 4 3 2 10 

aizi^^^ffl ^^^^ 250 



am p . 4.6.7.9 i^M ^^^-^ ^^^ 



9 8 7 6 5 4 3 2 10 



sign 



^ Register Ra |o!o!o!o!o'o!o!o!2 !6| (^ 



^ Register Rb |0.0.0 .0.0 .0.4.6.7 .9i ( + 



6.5.8 .4.3.7.2.0.4.01 Cell 450 before 



»;i5lO.Oa.7.9f;i«;iii Cell 450 after ^ _ Register Re Ijij^i^jilii^o .0.1.7.9} (p) 

division, before V_y 



division, before 
rounding . 



M:i|0.0.1.8.0|;iii:ii!;i Cell 450 after , Additional digit of quotient. 

rounding. 



H-4-6 



Example - DIVIDE RIGHT-JUSTIFIED 



Example 4 -D ivide a negative number by a positive number and round . V = 1 
Roundin/^ to cause overflow . 



98765432 10 


4 


2 3,6 


7.5 B 4 2.9 


1 


0|0 


2.0 5.1 4.3 



M 

DO 



> CCJ 



9 8 7 6 5 4 3 2 10 
leiiiigie^^^^^^ Cell 236 



mmmmiM.2.^r5m ceii 758 



8. 7. 8. 9. 2. 6.6. 2. 1.11 Cell 429 before 



Register Ra 



.^ Register Rb 



sign 
9876 5 43210 

PjO^^O.O.o:o.0.9.4.5l (V) 



10.0.0.0.0 .9 .4X5751 



;a^Jl«l;:l;|9.9l;e^^^^^ Cell 429 after ^ Register Re mmmmMO 9 9| (^ 

division, before » ■ • ■ •. . . . • .. •.• . v-.-.-v-v , , . /./ j \^^ 

rounding . 



iePieiilJU.o Tll^ Cell 429 after ^_ 

rounding, and 
insertion of sign. 
Overflow Alarm set. 



Additional digit of quotient. 



IV-4-7 



TABLE IV-1: 



Language Code 





NUMERIC 














NUMERIC BITS 














ZONE 


VALUE OF 




























BITS 


ZONE BITS 


0000 


0001 


0010 


0011 


0100 


0101 


0110 0111 1000 1001 


1010 


1011 


1100 


1101 


1110 


nil 


00 


III 





1 


2 


3 


4 


5 


6 7 8 9 


@ 





SPACE 


& 


• 


1 


01 


im 


. ~ 


A 


B 


C 


D 


E 


F G H 1 


D 


A 


m 


n 


9 


P 


10 


Hill 


+ 


J 


K 


L 


M 


N 


9 P Q R 


% 


£ 


$ 


( 


) 


/ 


11 


IB! 


♦ 


# 


S 


T 


U 


V 


W X Y Z 


d 


s 


u 


V 


W 


X 



TABLE IV-2: Modification of first word of Instruction by Index Register 



S-value 
4 
2 
1 



A syllable modified 
B syllable modified 
C syllable modified 



S-values of syllables 



Sum Determines combination 

of syllables modified. 



4 

J L 



2 
J u 



1 

J L 



If S = O, no Index Register is used, and R is irrelevant. 



TABLE IV-3: Interchange of syllables in 0OO 



(^00) before operation 







P 

, 1 1 


,Q, 




.. .M,t t r. 



(«00) after operation 



positive 
negative 



: . ; .p. 


Q^® 2 




"'7'^"^" Q® 2 

1^, ,t.,.„...< ■ L. I _.„ 


P 



DIVIDE LEFT-JUSTIFIED 

The respective contents of the A-f ield and the B-f ield 

rgi 

are left- justified, and the quotient -fPf is generated and stored, 
left- justified, in the C-field, and rounded. 

The Instruction has the restriction that the left-justi- 
fied contents of the A-field, regarded as a 10-digit number, imist 
be greater in magnitude than the contents of the B-f ield, similarly 
regarded. 

OVEHFLOW ALARM ; Will be set if the above restriction is violated^ 
or if an attempt is made to divide by zero. Note also that rotand- 
ing can cause overflow, and set the Overflow Alarm, 



IV-5-1 



INSTRUCTION FORMAT: 



9 


g 


7 


6 


5 4 

• 


3 


2 


1 

■ 1 ■■ » 


OP 


.A. 


B 
1 1 


.c. 




V 


M 


s 


R 


Al Ar 
1 


Bl BR 


Cl Cr 

..-Jt 



Operation: DIVIDE, LEFT- JUSTIFIED 

Operation Code: 5 



DEFINITIONS: 

Op: operation code. 

M: auto-monitor level: 0, 1, 2, 3. 

S: designates syllables for modification 
by index-register OOR, 

R: designates OOR as index register. 

A: base of address of divisor. 

Al, Ar: locations of left-most and right-most 
digits, respectively, of divisor. 

B: base of address of dividend. 

Bl, Br: locations of left-most and right-most 
digits, respectively, of dividend. 

C: base of address in which quotient is 
to be stored, 

Cl, Cr: locations of left-most and right-most 

digits, respectively, of field allocated 
to the quotient. 

V: variation designator; 

only the sign of V is relevant. 



IV-5~2 



DESCRIPTION OF: DIVIDE LEFT-JUSTIFIED 

CKI r -1 

This is a left-justified operation. ^ LPJ, roianded. 

- DO , 

(jUD is transferred^ left- justified, to a 10-characte.r~long 

working register (Ra) . Qb] is transferred, left- justified, to another 

lO-character-long working register (Rb). In the course of both these 

transfers , the zone-bits of all characters transferred are replaced by 

0-bits. 

At this point, the 10-digit number in Ra must be greater than 
the 10-digit number in Rb. The quotient, therefore, will be generated 
as though it .were a decimal fraction. 

The contents of Ra are then shifted one character-position to 
the right, introducing a zero digit at the left, and dropping the right- 
most digit. If £a] is 10 digits long, therefore, division is performed 
as though the rightnjiost digit were zero. The resiilt of this shift is 
to position the diYisor in Ra so that, when the -quotient is generated in 
a third 10-character-ldng working register (Re) , the first digit to the 
right of the imaginary decimal point will appear in position 2 ®^ ^®» 

The number of digits of the qtiotient generated in Re is the 
same as the number of digits allocated for the putaway in Cc]]. 

The contents of Re then replace Cd, left-justifiedo 

lext, the division is resumed, to generate one more digit of 
the quotient. If that digit is a "5" or greater, then [CH is augmented 
by "1«' , 

If the algebraic signs of the two operands are alike (as indi- 
cated hj the sign-bits of the digits in positions ki and Bl) then the 
sign of the quotient is positive; a 0-bit is inserted into the sign-bit 
position of Gl , If the algebraic signs of the two operands are unlike , 
then the sign of the quotient is negative | a 1-bit is inserted as the 
sign-bit of Gl . 

RESTRIGTIOMS g l) [A], regarded as a 10-digit left-justified number, 
must be greater than [^B], similarly regarded. Otherwise, the Overflow 
Alaim will be set, and no division will take place, 

2) An attempt to divide by zero will set Overflow Alalia, 
and no division will take place. 

3) If [_k'2 is more than 9 digits long, division will b© 
performed as though the right-most digit were zero, 

OVERFLOW ALAEaf; Will be set if restrictions 1 or 2 are violated. 

Rounding may cause a carry to be generated out of Gl; 
if so, the Overflow Alarm will be set. The carry will be lost. 



If-5--3 



Example - DIVIDE LEFT-JUSTIFIED 



Example 1 - Divide a positive number by a positive number , 
9 S 7 6 5 4 3 2 1 



-5. 


— 1 — 1 J 1 II 

2.4.2 4 2.2 S.S.S 


0|0 9 6.3 2.0 



sign 



967 6 543210 



4.2.3.5.4.0.0.0.0.5I Cell 242 

mmm m.i,o,6mmm ceii 422 



9S76543210 
-> Register Ra |4!2! 3!5!4!o! o!o!o' 5I (£) 



Register Rb 



Compare: (Ra)>(Rb) ^-^ 
2,1.0.6.0 . . 0. 0^01 (1) 



After the shift to position the divisor: Register Ra [0.4.2 .3. 5 .4.0.0.0.01 Qj 

liegister Rb |2 .1.0.6.0 .0.0. 0.0. 0| (^ 



9876543 2 10 



A.M.e^.U N.T.SP2.5.BJ Cell B8S before 



(Rb 
Tla 



■> (Re) 



i^;tiiiai»f;:ii!^ ' Cell 88^ after .( , Register Re 1 4 . 9 . 7 iJiJilJliJi^^ilMl (+} 



division, before 
rounding , 



;i;i;;i;i:Q;;;i[:;:;i;;;^^ Cell Bm after -f 

rounding. 



Additional digit of quotient 



Example 2 - Restriction violated, overflow alann set . 
9876543210 







9X2 











2.4,315,2.6 



9.0 2.1 4 



9 8 7 6 5 4 3 2 10 

1.9. 7.9.2. 0,1X23] CeX^ 9S2 



WMmw mm$\^^M ceix 243 



98765 43210 

-> Register Ra |1. 9.7 .9.2 .0.1.6.2 .51 Qj 

Compare: (Ra)<(Rb) 
-> Register Rb 15.4.0 .0 .0.O.0 .0^1 f^ 



Compare: (Ra) <(Rb) the overflow alam will be 

s^et , and no division takes 
place. 



J^W^fifhr 



TABLE IV-1: 



Language Code 





NUMERIC 














NUMERIC BITS 














ZONE 


VALUE OF 




























BITS 


ZONE BITS 


0000 


0001 


0010 


0011 


0100 


0101 


0110 0111 1000 1001 


1010 


1011 


1100 


1101 


1110 


nil 


00 


ill 





1 


2 


3 


4 


5 


6 7 8 9 


@ 


^ 


SPACE 


& 


• 


1 


01 


Hill 


— 


A 


B 


C 


D 


E 


F G H 1 


D 


A 


m 


n 


e 


P 


10 


■■II 


+ 


J 


K 


L 


M 


N 


9 P Q R 


% 


£ 


$ 


( 


) 


/ 


11 


ill 


♦ 


# 


S 


T 


U 


V 


W X Y Z 


d 


s 


u 


y 


w 


X 



TABLE IV-2: Modification of first word of Instruction by Index Register 



S-value 
4 
2 
1 



A syllable modified 
B syllable modified 
C syllable modified 



S-values of syllables 



Sum Determines combination 

of syllables modified. 



4 

J L 



2 

J I- 



1 

J L 



If S = O, no Index Register is used, and R is irrelevant. 



TABLE IV-3: Interchange of syllables in «00 



(*00) before operation 



» ..h \ u- 



P 

J L 



Q 



V 


(«00) after operation 


positive 
negative 










..» .* 


P 


Q ® 2 








O ^ 9 


p 




"■■ ••» * 




— , 1 1 



MODIFY A D D 

This instmction performs the special kind of addition 
required when the qtiantities to be added are addresses of memorj 
locations, or address-type tallies. This kind ©f addition is 
described and illustrated in Chapter III. 

The respective contents of the A-field and the B-field 
are right-Jmstified and added, ^ characters at a time * msing 
this special kind of addition. 

The resmlt is stored, right- justified, in the G-pmtawaj 
field. 

OVEBFLOW ALARM : Will not be;. set imder any circumstances. 



If-6-1 



INSTRUCTION FORMAT: 



9 


8 


7 


6 


5 4 


3 


2 


1 

1 > 


OP 


.A. 


^B^ ^ 


_ .c^ 




V 


M 


S 


R 


Al^ Ar 


Bl, Br 


Cl Cr 

t 



Operation: MODIFY ADD (MADD) 
Operation Codes 6 



DEFINITIONS: 

Op: operation code. 

M: auto-monitor level: 0, 1, 2, 3. 

S: designates syllables for modification 
by index-register OOR. 

R: designates OOR as index register. 

A: base of address of addend. 

Al, Ar: locations of left-most and right-most 
digits, respectively, of the addend. 

B: base of address of atjgend. 

Bl, Br: locations of left-most and right-most 
digits, respectively, of the augend. 

C: base of address in which sum is to be stored, 

Cl, Cr: locations of left-most and right-most digits, 
respectively, of field allocated to the sum. 

V: variation designator; 

only the sign of V is relevant. 



17-6-2 



DESCRIPTION OF: MODIFY ADD 

This is a right* jmstif led operation. 

CaD @ [b: — -^ CcD 

M is transferred, right- Justified, to a 12-eharacter-l8ng 
working register (Ra). Cb] is transferred, right-jmstified, to another 
12-character-long working register (Rb). 

In the course of both these transfers, the zone-bits of the 
right-most two characters in each gromp of three, are replaced by 0-bits, 

The contents of registers Ra and Rb yield fomr swas^ each of 
which is generated in the indicated field of a third 12 -character-long; 
working register (Re) . 

k 1 1 1 

(Ra:ll,9) (Ra2^6) (Ras53) (Ras2C)) 

Ok & (Si c^ 

\5 O v!? tj7 

(Rbsll,9) (Rbja6) (Rbs53) (Rb§20) 



(RcJll,9) (Rcja6) (Rcs53) (Rcs20) 

For detailed description of the operation designated by the 

symbol©, see discussion in Chapter III. Note that any **carry^' which 

may result from any of the four sums is ignored, and does not affect the 

next sum. 

The contents of Re then replace Cg] , right-Justified . 

OVERFLOW ALARM ; Will not be set by this Instruction. 



If -4^3 



Examples - MODIFY ADD 



E: 


K:ample 1 - 


987 6543210 

,^ f i 1 1 1 1 1 1 1 1 


Z 


2 3 3 4.0 5 5.5 





8.3 3.0 5.0 



9876543210 
l;i!l6.2.0.D.5.0^i^;^^l;:l Cell 233 



mmm^mm'^ .0 ^'i ,0 



Cell 400 



0. 2.0 .0 .A .2. 5 .D .4.01 Cell 555 before 



^ Register Ra IQ.Q.Q IQ.Q .0 16.2 .OlD.sTo 

© 

^ Register Rb lO.O.OjO.O .0 10.0.5 l0.5To 



i»^::;^l6.2.5.E.0.0i Cell 555 after ^ Register Re jO .0.0 |0.0 .016 .2 .5 |E .0 .0 



Example 2 



9 8 7 6 5 4 3 2 10 

11 • 1 111 I 1 1 


6 


5 5 5 


0.0 2 0.2 








9.0 9.0 9.0 



9876543210 



5.0.2.5.0.0.0.0.5.01 Cell 555 

Cell 002 



8.9. 9.0.2. 0.0. ^.9.0 



8.9.9.0.2.0.0.-H.9.01 Cell 002 before 



^ Register Ra 10.0.5 10.2 .5 |0 .0.0|0.5To 

© 



^ Register Rb |0.0.8i9.9 .0[2 ,0.0h .9.0^ 



^ 3.~.1. 5.2.0.0.J.4.0I Cell 002 after ^ Register Re |0.1.3 l~.l .5 (2 .O.OU .4.01 

Overflow Alarm will not be set. 



17-6-4 



Examples - MODIFY ADD 



Example 


3 - 


9876543210 
t 1 1 1 1 1 1 1 I 1 


6 


4.5.6 


2.5.0 3.3.0 


OlOO 9.0l9.0l9.0 



9876543210 
iZ.Z.8.4.-^.^-.-..M.N.P| Cell 456 



2.0.f^.ft.2.2.7.A.B.G 



Cell 250 



Register Ra IQ.Q. 9lZ.8.4l^.0.0lM.5.7! 

© 



^ Register Rb !0.0.2[0.8.8l2.2.7iA.2.3l 



lO.O.0. 0.0.0. 0.0.0. 01 Cell 330 before 



I1.0.7.2.S.2. 7.V.8.0I Cell 330 after ^ Register Re lQ.l.llo.7 .2 |S.2.7(V.8 .0 

Overflow Alann vrill not be set. 



Example 4 - 



987 6 5432 10 

1 1 1 i 1 1 1 < a 


6 


4 5 


0.0 5 0.5 








U^IAU. 



9876543210 

;Mi»^;ii.2.o.r:2{l Cell 450 



t:Si^;Mx0lA.3.O.B.3ll Cell 005 



10.C ) . Q,Q .A. 3 . 0.B . 3 . 0| Cell 005 before 



.^ Register Ra 



0.0.0I0.0.010.1.210.1.2 



© 



^ Register Rb Iq.o.oIo.q .oloa.310.2.3 



P i > P^P |2. 5. 0,3.^ P Cell 005 after ^ Register Re lo.O.OlO.O ■Ol0.2'.5lo.3.5l 



IV-.6-5 



TABLE IV-1: Language Code 



ZONE 
BITS 



NUMERIC 
VALUE OF 
ZONE BITS 

lilill 



NUMERIC BITS 
0000 0001 0010 0011 0100 0101 0110 0111 1000 1001 1010 1011 1100 1101 1110 nil 



00 
01 
10 

11 



0123456789@^ space & • ' 
-ABGDEFGHIDAmnep 
+ JKLMNe'PQR %£$()/ 
*#STUVWXYZdsuv^vrx 



TABLE IV-2: Modification of first word of Instruction by Index Register 



S-value 
. 4 

2 

1 



A syllable modified 
B syllable modified 
C syllable modified 



S-values of syllables 



Sum Determines combination 

of syllables modified. 



2 

J L. 



1 

J L 



If S = O, no Index Register is used, and R is irrelevant. 



TABLE IV-3: Interchange of syllables in ^00 



(^00) before operation 



t-u ,.,t 1 ri 



P 

J L 



Q 



V 



(0OO) after operation 



positive 
negative 



; 


..* » ,, 


P 


Q ® 2 












X.., ,,nt......,.-|M....U 


Q ® 2 

1 1 


p 



MODIFY SUBTRACT 

This Instruction performs an operation which is the 
reverse of the special kind of addition called MODIFY ADD. 
This operation is described and illustrated in Chapter III; 

The respective contents of the A-field and the B-field 
are right- justified, and the difference QAJ 9 [B] is generated, 
2 characters at a time, using this special kind of subtraction. 

The result is stored, right- justified, in the 
C-putaway field. 

If any 3-character field of GO should represent a 
smaller address^type number than the corresponding 3-character 
field of [B] , then the result of CA] Q Cb] will be the »4000t- 
compiement" of [b3 CaI . 

OVERFLOW ALARM : Will not be set under any circumstances. 



IV-7-1 



INSTRUCTION FORI^iAT: 

9^76 5 43210 



Op 


1 t 


: L. .. 

B 


1 1 

C 
^» • 




V 


M 


S 


R 


Al Ar 
1 


Bl Br 

» -. 


Cl Or 



Operation; MODIFY SUBTRACT (^UB) 
Operation Code? 7 



DEFINITIONS: 

Op: operation code. 

M: auto-monitor level: 0, 1, 2, 3. 

S: designates syllables for modification 
by index-register OOR. 

R: designates OOR as index- register. 

A: base of address of minuend. 

Al, Ar: locations of left-most and right-most 

characters, respectively, of the minuend. 

B: base of address of subtrahend. 

Bl, Br: locations of left-most and right-most characters, 
respectively, of the subtrahend. 

Cs base of address in which difference is to be 
stored. 

Cl, Cr: locations of left-most and right-most characters, 
respectively, of field allocated to the difference, 

V: variation designator; 

only the sign of V is relevant. 



17-7-2 



DESCRIPTION OF: MODIFY SUBTRACT 

This is a right-justified operation. 

[A] e CBl y Lc] . 

M is transferred, right- jmstified, to a 12-character-long 
working register (Ra). [BD is transferred, right-jmstified, to another 
12-character-long working register (Rb) . 

In the course of both these transfers, the zone-bits of the 
right-most two characters in each group of three, are replaced by 0-bits. 

The contents of registers Ra and Rb 3^! eld four smbtractions , 
each of which is generated in the indicated field of a third 12-character- 
long working register (Re) . 



k 


1 


2 


' 1 


(Ra:ll,9) 


(Ra:86) 


(Ra:53) 


(Raj2©) 


e 


# 


© 


e 


(RbJll,9) 


(Rb§a6) 


(Rbs53) 


(Rb:20) 



(Rc:ll,9) (Rc:a6) (Re: 53) (Rgs20) 

For detailed description of the operation designated by the 

symbol 6, see discussion in Chapter III. lote that any '* borrow** whifeh 

may resiilt from any of the four subtractions is ignored, and does not 

affect the next subtraction. 

The contents of Re then replace CcD , right- Justified. 

OVERFLOW ALARM : Will not be set by this Instruction. 



I¥-7-3 



Examples - MODIFY SUBTRACT 



Example 


1 - 


9876543210 

1 1 1 1 1 1 1 1 1 1 


7 


k 6 5 


5.7 5 a 2.2 





\0_0 


g.O 8.0 8.0 



9876 5 4 3210 
^liB.2.0.7.5.0.A.2.0| Cell 465 



^ Register Ra |0.0.0[B.2 .0 l7 .5 .0 lA .2 .0 



[jiiii.i .0.0.0.0.1.1.01 c^ii ^"^^ 



^ Register Rb jp .q.q H .1 .p [p .p .p |i ^i ^p 



1.0.0 .0. 5. 3. 5.E .4.(^1 Cell 822 before 



;i;|A.1.0.7.5.0.~.1.0l Cell 822 after ^ . Register Re {0 .0.0 |A.l .017.5.0 1-. 1.0 



Example 2 - 



98765432 10 


7 


2 


5.5 0.2 





Q 0' 


9.0 9.0 9.0 



9 8 7 6 5 4 3 2 10 



0.0.6.0.D.4.0.F.2.0I Cell 002 



Register Ea 



0.0. 010.6.0 Id .it.o If. 2.0 



1 .2 .8 .0 .1 .1 ,oirro1 Cell 550 



^ Register Rb 



0.0.112.8 .0 riM .OlHA .0 



.0 .0 .0 .0 .0 .0 .0 .0 .0 1 Cell 002 before 



9.x .a .O.C .3 .0.x .8 .01 Cell 002 after ^ Register Re IZ .9.91X.8 .0 IC .3 .0 IX .ao 



IV-7-4 



TABLE IV-1: 



Language Code 





NUMERIC 














NUMERIC BITS 














ZONE 


VALUE OF 




























BITS 


ZONE BITS 


0000 


0001 


0010 


0011 


0100 


0101 


0110 0111 1000 1001 


1010 


1011 


1100 


1101 


1110 


nil 


00 


IIIIH 





1 


2 


3 


4 


5 


6 7 8 9 


@ 


^ 


SPACE 


& 


• 


1 


01 


■III 


— 


A 


B 


C 


D 


E 


F G H 1 


D 


A 


m 


n 


e 


P 


10 


^^ 


+ 


J 


K 


L 


M 


N 


9 P Q R 


% 


£ 


$ 


( 


) 


/ 


11 


III 


* 


# 


S 


T 


U 


V 


W X Y Z 


d 


s 


u 


V 


w 


X 



TABLE IV-2: Modification of first word of Instruction by Index Register 



S-value 
4 
2 
1 



Sum 



A syllable modified 
B syllable modified 
C syllable modified 
Determines combination 
of syllables modified. 



S-values of syllables 



2 

J L. 



1 
J L 



If S = O, no Index Register is used, and R is irrelevant. 



TABLE IV-3: Interchange of syllables in «00 



(«00) before operation 



t .. u,t.....,.A r.1 . I I 



.^ 



(«00) after operation 



positive 
negative 



. . .p. ^®. 2 




1 s Q e 2 p 



EXTRACT 

This Instruction pemdts the contents of any desig- 
nated collection of hit-positions within a cell to be "extracted" 
from that cell, so that they may be examined without regard to 
the balance of the contents of the cell. 

An important use of this Instruction arises when a 
number of characteristics of an Item are coded in binary form, 
so that the Item may be easily classified according to any set 
of categories. 

This Instruction will operate equally well upon 
numeric infoi^aation which has been "packed" by the PACK Instruc- 
tion. 

0?ERFLO¥ ALABM ; Will not be set under any circumstances . 



H-a-1 



INSTRUCTION FORMAT; 



9 


8 


7 


6 


5 4 


3 


2 


1 

1 1 


Op 


,A. 


. B._ 


,c. 




V 


M 


S 


R 


Al, Ar 


Bl^Br 


Cl Cr 

1 



Operation: EXTRACT (EXT) 
Operation Code: 8 



DEFINITIONS: 

Op; operation code, 

M: auto-monitor level: 0, 1, 2, 3. 

S: designates syllables for modification 
by index-register OOR. 

R: designates OOR as index-register. 

A: base of address of first operand ("source"). 

Al, Ar: locations of left-most and right-most 
characters, respectively, of first 
operand. 

B: . base of address of second operand ("extractor"). 

Bl, Br: locations of left-most and right-most characters, 
respectively, of second operand. 

C: base of address in which result is to be stored. 

Cl, CR: locations of left-most and right-most characters, 
respectively, of the result. 

V: variation designator; 

only the sign of V is relevant. 



IV-.8-.2 



DESCRIPTION OF; EXTRACT 

This is a right- justified operation. 

CAD ,is transferred, right- justified, to a 10-character-long 
working register (Ra) , 

[BG is transferred, right- justified, to a 10-character-long 
working register (Rb) . 

A third IG-character-long working register, (Re) , is filled 
with zeros. 

Each of the sixty bits in Rb is exarained: wherever there is 
a 1-bit in Rb the corresponding 0-bit in Re is replaced by the corres- 
ponding bit, or 1, in Ra; wherever there is a 0-bit in Rb, the cor- 
responding 0-bit in Re is unaltered. 

The contents of Re replace DcH;, right-justified. 

It should be observed that tbe result generated in Re is the 
bit-by-bit "logical product" of the contents of registers Ra and Rb. 
This operation is symmetrical, in that the result will be unchanged if 
[AH and [Bj are interchanged. 

OVERFLOW ALARM ; Will not be set by this Instruction. 



W-^-3 



Example - EXTRACT 



Fro® LA_ 



IB. J 



To Qc 



Q.z£ 



Register Ra 

> (ooo ■ in mm . oi noio . lo ooo i 



From QbJ Register Rb 

SASI — — ^ /OOO. 10 1100 .01 100 .00 Olio 



Register Re 

■i /ooo. 10 1000 . 1 0000 .00 0000 



W-8-4 



TABLE IV-1: 



Language Code 



ZONE 
BITS 



NUMERIC 
VALUE OF 
ZONE BITS 

^^ 
^^ 



NUMERIC BITS 
0000 0001 0010 0011 0100 0101 0110 0111 1000 1001 1010 1011 1100 1101 1110 nil 



00 
01 
10 

11 



1 
- A 



23456789(s>^ space & * ' 
BCDEFGHIDAmnop 
+ JKLMN&PQR %£$()/ 
*#STUVWXYZdsu\rwx 



TABLE IV-2: Modification of first word of Instruction by Index Register 



S-value 
4 
2 
1 



A syllable modified 
B syllable modified 
C syllable modified 



S-values of syllables 



Sum Determines combination 

of syllables modified. 



4 

J L 



2 

J !_ 



1 
J L 



If S = O, no Index Register is used, and R is irrelevant. 



TABLE IV-3: Interchange of syllables in 0OO 



(^00) before operation 



y M""J| ' 



iu ,.l i fi I 



^±. 



V 


(0OO) after operation 


positive 
negative 














P 


Q ® 2 
















^ 


Q e 2 


P 




L_a.J..^..,Jt 


. -I-.., ,1 


1 — 1 — 1 — 1 



I H S E R T 

This Instimction permits a set of mew values of any 
designated collection of bit-positions within a cell to be 
"inserted" into that cell, withomt distmrbing the balance of 
the contents of the cell. 

An important mse of this Instruction arises when a 
nxamber of characteristics of an Item are coded in binary form, 
and one of the characteristics is changed, requiring a change 
in the binary coding. 

This Instruction will operate eqmally well upon 
numeric information which has been "packed" by the PACK In- 
struction. 

QfBBFLOW ALARM ; Will not be set under any circumstances . 



If-9-1 



INSTRUCTION FORMAT: 

9S765432 10 



QP 


A 


1 ;t....-ji 

B 
1 t 


, _t .t. „ 

C 
t 1 




V 


M 


S 


R 


Al, Ar 


Bl, Br 


Cl Cr 
1 



Operation : ' INSE RT ( SERT ) 
Operation Code: 9 



DEFINITIONS: 

Op: operation code. 

M: auto-monitor level: 0, 1, 2, 3. 

S: designates syllables for modification 
by index-register OOR, 

R: designates OOR as index-register. 

A: base of address of first operand ("source")* 

Al, Ar: locations of left-most and right-most characters, 
respectively, of first operand. 

B: base of address of second operand ("inserter"), 

Bl, Br: locations of left-most and right-most characters, 
respectively, of second operand. 

C: base of address of third operand, and result . 

Cl, Cr : locations of left-most and right-most characters, 
respectively, of third operand and result. 

V: variation designator; 

only the sign of V is relevant. 



IV-9~2 



DESCRIPTION OF: INSERT 

[aJ, [bJ, LPj ^^® each transferred, rlght-jtistified, to a 
lG-character-l©ng working register (Ra, Rb, Re , respectively) . 

Each of the sixty bits in Rb is examined: wherever there is 
a 1-bit in Rb, the corresponding bit in Re is replaced by the cor- 
responding bit, or 1, in Ra; wherever there is a ©-bit in Rb, the 
corresponding bit in Re is unaltered. 

The contents of Re then replace \j(]> right- justified. 

If \jf] happens to be zero, then the operation of INSERT is 
the same as that of EXTRACT. 

QfERFLQW ALAJJM ; Will n^t be set by this Instrmction. 



IV-9-3 



Ixanple - IISERT 



From [k] Register Ea 



^ 



From [b] 



To Co] 



( OOP. 00 0000 . II Q0Q0.00 10 1 I 



Register Rb 



m.@jj — ^ loOO.OI I 



100 



00 10 10.10 I J 00 



From LC] Register Re before insertion 

F.g^.s.d — ^ ( 110.10 Olio . 00 oioi .00 0000 



Register Eg after insertion 



F.K.5.8| ^ — - ^110.10 0010 . 00 OIOI . 00 1000 



J^-9-k 



TABLE IV-1; Language Code 





NUMERIC 














NUMERIC BITS 














ZONE 


VALUE OF 




























BITS 


ZONE BITS 


0000 


0001 


0010 


0011 


0100 


0101 


0110 0111 1000 1001 


1010 


1011 


1100 


1101 


1110 


nil 


00 


^^M 





1 


2 


3 


4 


5 


6 7 8 9 


@ 


^ 


SPACE 


& 


• 


» 


01 


^m 


— 


A 


B 


C 


D 


E 


F G H 1 


D 


A 


m 


n 





P 


10 


^^ 


+ 


J 


K 


L 


M 


N 


9 P Q R 


% 


£ 


$ 


( 


) 


/ 


11 


iiiiii 


* 


# 


S 


T 


U 


V 


W X Y Z 


d 


s 


u 


V 


w 


X 



TABLE IV-2: Modification of first word of Instruction by Index Register 



S-value 
4 
2 
1 



A syllable modified 
B syllable modified 
C syllable modified 



S-values of syllables 



Sum Determines combination 

of syllables modified. 



4 

J L 



2 

J L. 



1 

J L 



If S = O, no Index Register is used, and R is irrelevant. 



TABLE IV-3: Interchange of syllables in ^00 



(^00) before operation 



^„„„t 1 r.i 



P 

J L 



Q 



V 


(0OO) after operation 


positive 
negative 












..» A. ...*.. . 


p 

1 I 


Q e 2 












' 


V 


Qe 2 


p 











ADD BINARY 

The respective contents of the A-field and the B-field, 
right- justified , are treated as two 60-bit binary mambers. Their 
binary sum is generated, and stored from right to left in the 
C-putaway field. 

"Normal" variation ; The Instruction operates as just 
described. One of the principal uses for this operation -vdll be 
to add a binary^coded field to itself, and thus achieve a binary 
left shift of one bit-position. In this way, characteristics 
which have been recorded in binary-coding, may be successively 
tested, 

"Mod-64" variation ; In this variation, binary addi- 
tion takes place character by character > with no carry between 
characters. In this manner, the individual characters ©f a 
sorting-key may be transformed into pseudo-characters, which 
will sort into a sequence different from the normal sequence of 
the 304 Language Code. Normal sorting routines may then be used 
to achieve any desired sorting sequence. 

Q?ERFLO¥ ALASM ; Will be set if the sim exceeds the capacity of 
the C-field. 



If-D-l 



INSTRUCTION FORMAT j 

9S76543210 



Op 


A 

« 


1 I 
B 

8 ! 


C 




V 


M 


S 


R 


Al Ar 

— «, _. 


Bl Br 


Cl Cr 



Operations ADD BINARY (BINA) 
Operation Code; Q 



DEFINITIONS: 

Ops operation code, 
Ms auto-monitor level: 



KJ * JL « ^9 -^ • 



S; designates syllables for modification 
by index-register OOR. 

Rs designates OOR as index- register^ 

As base of address of addend. 

Al, Ars positions of left-most and right-most 
characters, respectively, of addend. 

Bs base of address of atigend. 



Bl, Br 



Cl, Cr; 



positions of leftr-most and right-most 
characters, respectively, of augend. 

base of address in which the binary sum 
is to be stored. 

positions of left-most and right-most 
characters, respectively, of the field 
allocated for the sum. 



Vs variation designator: 



V 


Specifies 


Abbreviation 





Nonnal 


BDJA 


1 


Mod-64 


BINA:M 



IV-Cj-2 



DESCRIPTION OF: ADD BINARY 

This is a right- jmstified operation. 

(JG is transferred, right- justified, to a 10-character-l(?ng 
working register (Ra) . £b2 is transferred, right- jmstified , to another 
10-character-long working register (Rb). 

The contents of registers Ra and Rb are considered as positive 
binary ntmbers , each 60-bits in length. 

¥ = : The contents of registers Ra and Rb are added binarilj, the 
60-bit binary simi being generated in a third working register (Re), 11 
characters long. 

Y = 1 ; The binary addition is performed as in ? = 0, except that no 
carry is generated between character-positions in register Re. Thms 
the transformation of each character is independent of the resiilt of 
the transformation of any other character. 

The contents of Re then replace QcJ, right-^ justified. 



0TERFI.0W ALARM ; Will be set if some character (other than "zero") is 

not transferred from Re to CQD» 

ADDITION TABLE for Add Binary (Bit-by-bit addition) 



"J-" is the special symbol used to designate 
binary addition. 



H/»» 



J. 





1 





: 


1 


1 


1 ,. 


C0 



c" indicates carry into the next bit-position < 



IY-n-3 



Example - ADD BINARY , ¥ = . ("Normal") 



In p3X>cessing an industrial payiroll, there are 24 possible deductions 
from an employee's Gross Pay. In each employee's payroll file, a 4-character 
field has been allocated for recording the presence or absence of each of 
these deductions I each of the 24 bit-positions in this field corresponds to 
one deduction. A l~bit in any position indicates that the corresponding de- 
duction is to be made, -while a Q-bit indicates that the deduction is not to 
be made. The 24 bit-positions are assigned to the deductions in their 
relative order of frequency, with the most frequently-used deduction assigned 
the left-most bit-position. 



An employee's payroll file has been read from Magnetic Tape into Memory; 
F$kt% contains the deduction code. The folio-wing flow-chart indicates the 
program to test for the presence of each deduction, and terminate when the 
last deduction in an individual file has been detected. 



ADD BIN (¥=0); 

(F94;96) J- "Zero" - > 09:30 Plant binary-coded field in Working Storage, 



Clear appropriate syllables of (OOR) 



COMP EQUAL: (^0^:30) vs "Zero" Finished? 



r^ ADD BIN (¥=0) : 



(09:30) J- (Wi30) 



^09^30 Shift field left one bit-position, 



TEST Overflow (See Note below) 



ji2l^ J GGMT in (OOR) 
=24 



No more deductions 
for this employee 



Process deduction corresponding 
•¥) to count in (OOR). Use (OOR) 
to modify the Instructions 
which examine a table; the 
table contains directions for 
processing each of the deductions 



NOTE: If the left-most bit of (09:30) is a 1-bit, then the operation 
of ADD BINARY (shift the field left one bit-position) will 
result in Overflow. 



I¥-n-4 



Suppose that ded-uctions #0, #2, #3 are to be made from the Gross Pay of a 
particular employee. 

Then, at the start of the testing loop, (^09? 30) vdll appear as: 



Character- 
position - 

Deduction 

Present or 
Absent 

The effect of adding a binary field to itself is to shift the field 1 bit-position 
to the left. The left-most bit is lost, and a 0-bit appears at the right end. 
After the first ADD BINARY, (^09? 30) will contain: 



3 2 


% 






#0 #1 ^ #3 #4 #5 #6 #7 #8 #9i. 








1 1 1 Ot, 


(bit-w 
tion) 



( 1-bit lost) 































"T^ Overflow Set; 



Make Deduction #0. 



After the second ADD BINARY, (^09:30) will contain: 
(0-bit lost) 































TT^ No Overflow. 

_!!> Omit Deduction #1, 



After the third ADD BINARY, (^09: 30) will contain: 
(1-bit lost) 































"77 Overflow Set; 
SJ^ Make Deduction #2, 



After the fourth ADD BINARY, (^09:30) will contain: 



(1-bit lost) 



























7~prL Overflow Set; ,, 
__Ey Make Deduction #3. 



But now, as the operation comes around to the beginning of the loop again, 
and executes the COMPARE EQUALITY, (^09:30) = 0, and no further testing is 
done . 



Br-D-5 



Example ~ ADD BIMARY, ¥ = 1 . (»»mod-6V0 

Heqiiired: To sort data according to some kej (part number, aecoimt 
nira.ber,&c), msing standard Sorting Romtines, despite the fact that the 
follo'wing sorting sequence (which is different from the Pix>Gess©r sort- 
ing sequence) is required: 

''space", *'-*', letters, digits. 

This requires one Instruction as part of regimenting the input for sortingj 
ADD BIHARY (¥=l): Sorting key ^ "Umi...U» V Sorting key . 

Each character of the sorting key is independently transJEonned into a 
pseudo-character in such a way that, when the pseudo-key is sorted, the 
items will be arranged in the desired orders 



Pseudo- 
Character Character 

^ U 



1 ■ ^ 1 

* . . • 

9 __^ V 

space- > Q 

• « 
- ^ 4 



A > 5 

• • 

N ^ I 

« * 

Z — > ( 



In the Master File , the items will be stored with their keys in pseudo- 
characters; all Searching, Gopying and posting will be performed with 
pseudo-keys, and it is only necessary to reverse the transformation, 
from pseudo-key back to otdginal key, for output printing. 

The transformation is reversed by including one additional Instruction 
in the Editing Routine: A field of all "spaces" is added to the pseudo- 
key, using this variation of ADD BINARY. 

More elaborate transformations into pseudo-keys may be performed by 
using TEST BIT and COMPLEMENT BINARY, in addition to the "mod~64" 
variation of ADD BINARY. These are illustrated under COMPLEMENT BINARY. 



I?-D-6 



TABLE IV-1; 



Language Code 





NUMERIC 














NUMERIC BITS 














ZONE 


VALUE OF 




























BITS 


ZONE BITS 


0000 


0001 


0010 


0011 


0100 


0101 


0110 0111 1000 1001 


1010 


1011 


1100 


1101 


1110 


nil 


00 


■111 





1 


2 


3 


4 


5 


6 7 8 9 


@ 


^ 


SPACE 


& 


• 


1 


01 


^^ 


— 


A 


B 


C 


D 


E 


F G H 1 


D 


A 


m 


n 


e 


P 


10 


■ill 


+ 


J 


K 


L 


M 


N 


P Q R 


% 


£ 


$ 


( 


) 


/ 


11 


■■■ 


♦ 


# 


S 


T 


U 


V 


W X Y Z 


d 


s 


u 


v^ 


w 


X 



TABLE IV-2: Modification of first word of Instruction by Index Register 



S-value 
4 
2 
1 



A syllable modified 
B syllable modified 
C syllable modified 



S-values of syllables 



Sum Determines combination 

of syllables modified. 



4 

J L 



2 
J I. 



1 

J L 



If S = O, no Index Register is used, and R is irrelevant. 



TABLE IV-3: Interchange of syllables in «00 



(«00) before operation 



tu ,..h .L r. 



J L 



Q 



V 


(*00) after operation 


positive 
negative 




-™ 


.*rr.n'.....i.i..i ,, i. 


n 








. t. ...h, 

■ IIIIIHHIIII 1 

j 


r 

i 1 ,„ 


Vi vy 2 
P 


1 — J 


\, :,f t 3 




1 1 



COMPLEMENT BINARY 

The contents of the A-field, right- justified, are 
treated as a 60-bit binary field. This field is complemented 
by changing a3J. its 1-bits into 0~bits, and all its 0-bits 
into 1-bits, and is stored from right to left in the G-pmtaway 
field. 

If the G-field is longer than the A-field, it will 
be filled otit to the left with "x»s'» (code 11 1111) « 

OYEBFLOW ALARM ; Will not be set under any circumstances. 



I^-Ar-l 



INSTRUCTION FORxMAT: 

9^7 65 4 32 1 



OP 



:v:':':':-:->:y:y::: 



V 



M 



R 



Al Ar 






I Cl Or 



Operation: COMPLEMENT BINARY (BINC; 
Operation Code ; ^ ( V = l ) 



DEFINITIONS: 

Op: operation code. 

M: autoHnonitor level: 0, 1, 2, 3» 

S: designates syllables for modification 
by index-register OOR. 

R: designates OOR as index-register. 

A: base of address of field which is to 
be complemented. 

At, Ar: positions of left-most and right-most 
characters, respectively, of A-field. 

C: base of address in which the complemented 
A-field is to be stored. 

Cl, Cr: positions of left-most and right-most 
characters, respectively, of field 
allocated for the complement. 

V: variation designator; 

V = 1 specifies COMPLEMENT BINARY. 



I7-A-2 



DESCRIPTION OF: COMFIEMENT BINARY 

This is a right- justified operation. 

CAH is transferred, right-jtistified, to a 10~character- 
long working register (Ra) . 

The contents of Register Ra is then transferred to 
another lO-character-long working register (Re) . In the course 
of this transfer, all 1-bits are replaced by 0-bits, and all 
O-bits are replaced by l~bits. 

The contents of Register Re then replace LOH, right- 
justified. 

OVERFLOW ALARM ; Will not be set by this Instruction. 



I^-A-3 



Examples - COMPLEMENT BINARY 

Example 1 - Generate a field of all 1-bits ("xxxxxxxx") in F34:92, given 
that (007:99) = 0. 



9876543210 



r+rrr^r 



0.0.7 



mm w3 , k 







9.9«;;gl9.2 



9876543 2 10 

nmmmMmmmmm ceii 007 

^ l::-:-:.:.;-- .v--.-.M.-.-:-:i:-:-:-:i:->:-M-:-v-v.---.i-.v.-: 



9^76543210 



J I I 1 L 



^ Register Ra |o. Q.Q .0.0 .0.0.0.0 .0 



I7.9.0.2.0.4.6.2.3.0I ^^^^ ^^^ ^®^°^^ 



x.x.x.x,x.x.x.xll;i;i^ Cell F34 after ^ Register Re Ix.x.x.x.x.x.x.x.x.xl 



Example 2 - The sales records of 5000 salesmen are to be sorted, 
so that the salesman with the greatest dollar-amount 
of sales shall head the list , and the salesman with 
the lowest dollar-amoiint of sales shall be at the 
bottom of the list. 

In order to conserve Magnetic Tape storage space for 
the file, and also to permit the Sort to proceed most 
rapidly, all numeric information in each salesman* s 
record has been PACKED. 

Required, therefore, to transform, the sorting key (the 
field containing PACKED dollar-amoomt of sales) so that 
normal Sorting Routines will sort the list into reverse 
order. 

To do this, it is necessary merely to COMPLEMENT BINARY 
the packed dollar-amount in each record, then sort. 
lAJhen the sort has been completed, the dollar-amounts 
are re-COMPLEMENTED , and UNPACKED for printing. 



iv-A-4 



Example 3 » While the following problem, as such, will not be 
encountered often, it probably presents as ccsnplex 
a sorting transformation as the programmer will ever 
be required to perform, and it is therefore given as 
an illustrative example. 

Required: 

Using standard Sorting Routines, sort a collection of street- 
addresses alphabetically by name of street. The house-numbers on each 
street are to be sorted so that by following " the sorted list, a person 
will start at the South end of each North-South street, and at the West 
end of each East-West street, walk along the odd-numbered side of the 
street the full length (or width) of the city to its Northern (or 
Eastern) boundary; then cross the street and walk along the even- 
numbered side of the street, all the way back to its South (or West) end. 

This requires that the house-numbers on any street shall be 
sorted in the following sequence: 



"lowest" numbers 
next 
next 
"highest" numbers 



S or W odd, in reverse sequence 
N or E odd, in forward sequence 
N or E even, in reverse sequence 
S or W even, in forward sequence 



Therefore, the sorted list for North-South streets, for example, 
will look like this: 



Start walking 
North 



D- 



Cross the 
street and 
walk South. 



•10999 S 

10997 S 

10995 S 

• • • s 

• • • k3 

3 S 
1 S 

1 N 

3 N 
. . • N 
. . , N 
17999 N 
17998 N 
17996 N 
. . . N 
. . • N 

k N 

2 N 
2 S" 

4 S 

• • • ^ 

• • • o. 

10996 S 

10998 S 



Southern boundary of the city 



Cross Main Street 



Northern boundary of the city 



Cross Main Street 



Southern boundary of the city 



IV-A-5 



Assume: 



Each item has been already rerjl'nented for sorting 
9 8 765/^3210 



G97 
G98 

G99 
HOO 
HOI 
H02 



iiiil 


ylyX*Uy,* 






s s s 


s s 


s s s s s 


s s s 


s s 


n n n n n 


;;;.'v:';';';v:v;' 






X ifiiViiMMMiM^^ 



o • • • • (S 



nminn 



represents the street name, filled out to the 
right v/ith spaces , 

represents the 5-digit house-number, filled out 
to the left with zeros. 

X represents on^a of the letters N, E, S, or W which 

has been stored in an otherwise unused position. 

Note that, for the MERGE, (G99:90) is the major key, 
and (HOO: 90) is the minor key. N, E, S, or W is not part of the key. 

The codes for the letters representing the four 
directions are: 

N: 10 0101 
E: 01 0101 
S: 11 0010 
W: 11 0110 

lEST BIT Instructions, coded as follovrs, will cause 
a Jump under the conditions shown: 



A-fiol^q 



B-field 



(H02:99)— vs "1" 



"w" 



vs-(H00:00). 



(HOO: 00)- vs— "1»» 



Jump if 

N or E 
Even 
Odd 



Step if 

S or W 

Odd 
Even 



There are many ways of performing the desired sorting 
transformation by transforming the house-numbers. The most 
straight-forward set of transformations is? 



S & W odd : 
N & E odd : 
N & E even: 
3 St W even: 



Zone 0, backward: 

Zone 1, forward : 

Zone 2, backward: 

Zone 3, forward : 



Add "^HHHHf", Ccmplement. 

Add " ". 

Add ••— »«, Ccmplement 

Add "-JHHHHi-ll, 



It must be understood that wherever, in this example, the 
operation "Add" is mentioned, it is to be understood as ADD DINAHY (V "-IJ, 



iv^.6 



v_. 



The following Constants are required: 
9876543210 



U6 
LU7 






(In actually coding this problem, the "w" and "1" 
would be stored in irrelevant character-positions 
of the Instructions. However, for simplicity, 
they are shown separately here.) 



TEST BIT: 

(H02:99) vs (U7:88) 



N&E 



ADD BIN (V=l): 
(H00:40) J- (L46:95) 
— -^H00:40 



TEST BIT: 

(L47:99) vs (H00:00) 



COMPLEMENT BIN: 
(H00:40)- — )'H00:40 




ADD BIN (V=l): 
(H00:40) i. (L46:40) 
- — ?^H00:40 



TEST BIT: 

(H00:00) vs (L47:88) 



CCMPARE EQUALITY: 
(HOOtOO) vs {H00:00) 
— Unconditional Jump. 



COUNT: for next item. 



Standard 
Sorting Routine 



Reverse 
the Transformations 



The program to reverse the transformations will be 
very similar to that shown above. 



The entire process of performing the transformations, 
and later reversing them, increases the total 
sorting time by 10 minutes per 100,000 items. 



ivA? 



TABLE IV-1: Language Code 



ZONE 
BITS 



00 
01 
10 
11 



NUMERIC 
VALUE OF 
ZONE BITS 



i 

I .1 



NUMERIC BITS 
0000 0001 0010 0011 0100 0101 Olio 0111 1000 1001 1010 1011 1100 1101 1110 nil 



1 

- A 

+ J 

* # S T 



234567 8 9@^ space & • 
BCDEFGHIDAmno 



KLMN&PQR%£$ ( ) / 



U V W X Y Z 



w X 



TABLE IV-2: 



Modification of first word of Instruction by Index Register 



S-value 
4 
2 
1 



Sum 



A syllable modified 
B syllable modified 
J syllable modified 
Determines combination 
of syllables modified. 



S-values of syllables 



2 

J L. 



1 
J L 



If S = O, no Index Register is used, and R is irrelevant. 



TABLE IV-3: Interchange of syllables in ^0 



(000) before operation 



5W.;.M.W."."^^mBp!W 



MiMiiiviil£f{mi1lliii»i^ 



P 

J L 



Q 

I I 



positive 
negative 



(^00) after operation 



no branch 



P 

J L 



Wt-!-H4HWW:SH- ! -H;WHj- ! :H-'- ' ' 



P 

J L 



Q ® . 2 



Q ® 2 

-Zj L_-_ 



branch 



K^'ii-'i£-'-'-''y'i'"fl'-f''fi}>i}^f^: 



P 

J U 



itiiiiiiiaiiiiiiMBii'fiSiwyft'K'K' 



Q © 2 
__J I 



J 

J L 



TEST BIT . 

This Instruction is used to test for the presence or 
absence of any conditions which have been expressed and recorded 
in binary coding. 

Th-us, categories such as payment status of Acco-unts 
Receivable; availability of machines for loading; ability of 
laachines to perform desired operations; geographic location, 
credit status, classification, &c of custoiaers — may all be 
selected singly or in combination with the ^ST BIT Instruction. 



I7~A-1 



INSTRUCTION FORMAT: 

9^76 5 4 3 21 



B 



Operation: TEST BIT (TBIT) 
Operation Code: A 



V 



M 



R 



Al Ar 



Bl Br 



DEFINITIONS: 

Op: operation code. 

M: auto~monitor level: 0, 1, 2, 3. 

S: designates syllables for modification 
by index-register OOR. 

R: designates OOR as index register. 

A: base of address of first operand. 

Al, Ar: locations of left-most and right-most characters, 
respectively, of first operand. 

B: base of address of second operand. 

Bl, Br: locations of left-most and right-most characters, 
respectively, of second operand, 

J: base of address of next instruction if 
tested condition is met. 

V: variation designator; 

, only the sign of V is relevant. 



IV-A-2 



DESCRIPTION OF: TEBT BIT 



This is a right-jmstified operation. 

[AU is transferred, right-justified, to a IG-character-long 
working register (Ra); CbH is transferred, right- justified to another 
lO-character-long working register (Rb) . 

The respective contents of registers Ra and Rb are compared, 
bit-position by bit-position. The comparison may be regarded in either 
of two ways, which are logically equivalent; 



I- The instruction whose address is designated by J will be 
executed next, if the result of the comparison is one of the following? 

a) Wherever there is a 1-bit in Rb, there is a 1-bit 
in "the corresponding bit-position in Ra , 

b) Rb contains all O-bits. 

The next instruction in sequence will be executed next, if for 
any 1-bit in Rb there is a ©-bit in the corresponding bit-position of Ra, 

II- The instruction whose address is designated by J will be 
executed next, if the result of the comparison is one of the following; 

a) Wherever there is a 0-bit in Ra, there is a O-bit 
in the corresponding bit-psotion in Rb. 

b) Ra contains all 1-bits. 

The next instruction in sequence will be executed next, if for 
any 0-bit in Ra there is a 1-bit in the corresponding bit-position of Rb. 



That iss JUMP IF: 

I - CaU contains all the 1-bits of [BU, 
II - LbD contains all the Orbits of CA]. 



I?-A-3 



TABLE IV-1: Language Code 



ZONE 
BITS 



00 
01 
10 
11 



NUMERIC 
VALUE OF 
ZONE BITS 



i 



NUMERIC BITS 
0000 0001 0010 0011 0100 0101 Olio 0111 1000 1001 1010 1011 1100 1101 1110 nil 



0123456789(0)^ space & • « 
-ABCDEFGHIDAmnop 
+ JKLMNerPQR %£$()/ 



#STUYWXY 



s u 



w X 



TABLE IV-2: Modification of first word of Instruction by Index Register 



S-value 
4 
2 
1 



Sum 



A syllable modified 
B syllable modified 
J syllable modified 
Determines combination 
of syllables modified. 



S-values of syllables 



2 
J u 



1 

J L 



If S = O, no Index Register is used, and R is irrelevant. 



TABLE IV-3: Interchange of syllables in «00 



(^00) before operation 






J L 



Q 



positive 
negative 



(^00) after operation 



no branch 



■H*!-WWR«*H*!*H 



P 

4 L 



P 

J L 



Q © .2 



Q.®.^ 



branch 






Q © 2 
_ji I 



COMPARE NUMERIC 

This Instruction regards the contents of the A~ and 
B-fields as ntambers, each with algebraic sign. 

If the right-JTistified A-field contains a greater 
ntmber than the idght-jtistified B-field^ then the next Instruct 
tion to be executed will be selected from a "branch" address 
specified in the Instnietioni otherwise, the next Instruction 
in normal sequence will be executed. 

It will be recalled, of course, that amy positive 
number is greater than any negati-ye numberi and that, of two 
negative numbers, the one with the greater magnitude is the 
smaller number. 



IV-B-.1 



INSTRUCTION FORMAT: 



9 


8 


7 


6 


5 4 

• 


3 


2 


1 
1 1 1 


Op 


A 
• 1 


B 
1 t 


J 
1 • 




V 


M 


S 


R 


Al, Ar 


Bl.Br 


iiiiii 



Operation: COMPARE NUMERIC (GN) 
Operation Code; B 



DEFINITIONS: 

Op: operation code. 

M: auto-monitor level: 0, 1, 2, 3. 

S: designates syllables for modification 
by index-register OOR, 

Rj designates OOR as index- register, 

A: base of address of first operand. 

Al, Ar: locations of left-most and right-most characters, 
respectively of first operand. 

B: base of address of second operand. 

Bu, Br: locations of left-most and right-most characters, 
respectively, of second operand. 

J: base of address of next instruction if LAI1>CBI1, 
numerically. 

V: variation designator; 

only the sign of V is relevant. 



W-ft-a 



DESCRIPTION OF: COMPARE NUMERIC 



This is a right -justified operation. 



[A] is transferred, right- justified, to a 10-character-long 
working register (Ra). £B2 is transferred, right- justified to another 
10-character-long working register (Rb) . In the course of both these 
transfers, the zone-bits of all characters transferred are replaced by 
0-bits . 



The algebraic signs of QAJ and £B] (as indicated by the 
respective sign-bits of the characters in positions At and Bl) are 
exaniined, and four cases are recognized: 



1- If both signs are positive, the contents of registers Ra and 
Rb are compared. If (Ra) is a greater number than (Rb), then the next 
Instruction to be executed will be selected from the address specified 
by J, If (Ra) is less than or equal to (Rb), the next Instruction in 
sequence will be executed. 



2- If both signs are negative, the contents of registers Ra and 
Rb are compared. If (Ra) is a smaller number than (Rb), then the next 
Instruction to be executed will be selected from the address specified 
by J. If (Ra) is greater than or equal to (Rb), the next Instruction 
in sequence will be executed. 

3- If the sign of CA-U is positive, and the sign of [Bj is negative, 
the next Instruction to be executed will be selected from the address , 
specified by J. * 

4- If the sign of QA]] is negative, and the sign of CbH is positive, 
the next Instruction in sequence will be executed. 



NOTE : Positive zero will always be a greater number, for the purpose 
of this Instruction, than negative zero . 



I\r-B~3 



TABLE IV-1: Language Code 



ZONE 
BITS 



NUMERIC 
VALUE OF 
ZONE BITS 



NUMERIC BITS 
0000 0001 0010 0011 0100 0101 Olio 0111 1000 1001 1010 1011 1100 1101 1110 nil 



00 
01 
10 

11 



i 
a 



1 2 3 4 5 6 7 8 9 @ < space & • 
-ABCDEFGHIDAmn9 
+ JKLMN&PQR%£$() 



#STUYWXYZ 



s u 



W X 



TABLE IV-2: Modification of first word of Instruction by Index Register 



S-value 
4 
2 
1 



Sum 



A syllable modified 
B syllable modified 
J syllable modified 
Determines combination 
of syllables modified. 



S-values of syllables 



2 

J L. 



1 

J L 



If S = 0, no Index Register is used, and R is irrelevant. 



TABLE IV-3: Interchange of syllables in »00 



(^00) before operation 


^^^■i 


p 

— i- — 1 — 


Q 

1 1 



V 



positive 
negative 



(^00) after operation 



no branch 






Q ® . 2 






P 

I I 



Q ® 2 



branch 



ft?;Va¥i?i'i'i^Wi'Mi'3iW;?;'i'i 



lWK'l*-H-Hj!f>yil:!:!i!:W;y:I:li!i;:y!i!.! 



Q e 2 



J L 



COMPARE ALPHA-NUMERIC 

This Instruction regards the contents of the A- and 
B-fields as alpha-niameric information. 

If the right-jtistified contents of the A-field follows 
the right- jTistified contents of the B-field, according to the 
"sorting sequence" shown in Table I\r-1, then the next Instruction 
to be executed will be selected from a "branch** address specified 
in the Instruction; otherwise, the next Instruction in normal 
sequence will be executed. 

If positive numbers have been PACKED, the result of 
COMPARE ALPHA-NUMERIC ^11 be the same as if the information 
were in unpacked form. 



INSTRUCTIOx^ FORMAT: 

9 8 7 6 5 4 3 2 10 



on .A 



B 



J L 



ajLu 



Operation: COMPARE ALPHA-NUMERIC (^A) 
Operation Code: C 



M 



R 



Al. Ar 



Bl Br. 



DEFINITIONS: 

Op: operation code, 

M: a\ito-monitor level: 0, 1, 2, 3. 

S: designates syllables for modification 
by index-register OOR. 

R: designates OOR as index-register. 

A: base of address of first operand. 

Al, Ar: locations of left-most and right-most characters, 
respectively, of first operand. 

B: base of address of second operand. 

Bl, Br: locations of left-most and right-most characters, 
respectively, of second operand. 

J: base of address of next Instruction if LA] 

follows LBH, in the Processor's sorting sequence, 
i.e.- if CAJ^LB], when both are regarded as 
positive binary numbers. 

V: variation designator; 

only the sign of V is relevant. 



IV-C-2 



DESCRIPTION OF: COMPARE ALPHA-NUMRIG 

This is a right- justified operation, 

CA] is transferred, right- justified, to a lO-character-long 
working register (Ra). CBH is transferred, right- justified, to another 
lO-character-long working register (Rb). 

The contents of registers Ra and Rb are regarded as positive, 
60-bit-long binary numbers, and are compared. 

If (Ra) is a greater binary number than (Rb), then the next 
Instruction to be executed will be selected from the address specified 
by J; otherwise, the next Instruction in sequence will be executed next. 

Since the "sorting sequence'* of the 64 characters which are 
significant to the Processor (as shown in Table I^-l) is the same as 
the numeric sequence of their binary configurations, the comparison has 
the effect of determining whether or not (Ra) follows (Rb) according to 
the alpha-numeric sorting sequence of the Processor » 

If the COMPARE ALPHA-HI3MERIG Instruction is applied to signed 
numeric quantities, a negative number will always follow a positive 
number in the sorting sequence. 

An important consequence of the correspondence between the 
binary sequence and the alpha-numeric sorting sequence, arises in con- 
nection with the PACK Instruction (Code SQj applied to positive numeric 
information* After this information has been PAGKed, the relative 
significance of the binary bits comprising that information is unchanged, 
and COMPARE ALPHA-MUMERIG will always give precisely the same result as 
if the information had not been packed. 



IV-C-3 



TABLE IV-1; Language Code 





NUMERIC 














NUMERIC BITS 
















ZONE 


VALUE OF 






























BITS 


ZONE BITS 


0000 


0001 


0010 


0011 


0100 


0101 


0110 0111 1000 


1001 


1010 


1011 


1100 


1101 


1110 


1111 


00 


H 





1 


2 


3 


4 


5 


6 7 8 


9 


@ 


^ 


SPACE 


& 


• 


9 


01 


^H 


— 


A 


B 


C 


D 


E 


F G H 


1 


D 


A 


m 


n 


9 


P 


10 


^^i^gjg^ 


+ 


J 


K 


L 


M 


N 


e P Q 


R 


% 


£ 


$ 


( 


) 


/ 


11 


mmmm^ 


* 


# 


S 


T 


U 


V 


W X Y 


Z 


d 


s 


u 


Y 


W 


X 



TABLE IV-2: Modification of first word of Instruction by Index Register 



S-value 
4 
2 
1 



Sum 



A syllable modifiied 
B syllable modified 
J syllable modified 
Determines combination 
of syllables modified. 



S-values of syllables 



4 

J L 



2 

J L. 



1 
J L 



If S = O, no Index Register is used, and R is irrelevant. 



TABLE IV-3: Interchange of syllables in »00 



(<eOO) before operation 



f^s^i^mmm 



Q 



positive 
negative 



(^00) after operation 



no branch 






Q ® 2 
■ « 



^« 



i22Lfc.--J L-L-L 



Q ® 2 

2h I 



branch 



P 

J 1. 



■:•«•!•:«•.•?:•:•:!?«•:•■•:•:■:•>:¥: 



I Q e 2 



COMPARE EQUALITY 

This Instraction right-Justifies, and compares, the 
contents of the A- and B-fields. 

If the contents of both fields are the same, then 
the next Instraction to be executed will be selected from a 
"branch" address specified in the Instruction; otherwise, the 
next Instruction in the normal sequence will be executed. 



n-D-1 



INSTRUCTION FORMAT: 



9 


8 


7 


6 

1 r 


5 4 
• 


3 


2 


1 
1 « 


Op a 


B 
1 1 


J 
1 i 






V 


M 


S 


R 


Al Ar 
1 


Bl Br 





Operations COMPARE EQUALITY (GE) 
Operation Codes D 



DEFINITIONS: 

Op J operation code. 

M: auto-monitor level: 0, 1, 2, 3. 

S: designates syllables for modification 
by index-register OOR, 

R: designates OOR as index register. 

A: base of address of first operand, 

Al, Ars locations of left-most and right-^nost characters, 
respectively, of first operand. 

Bs base of address of second operand. 

Bl, Brs locations of left-most and right-most characters, 
respectively, of second operand. 

Js base of address of next Instruction if 
LK\ ** EB], in every bit-position. 

Vs variation designator; 

only the sign of V is relevant. 



rv-D-2 



DESCRIPTION OF: COMPARE EQUALITI 

This is a right- justified operation. 

Ca] is transferred, right- jtistified, to a lO-character-long 
working register (Ra) . £B] is transferred, right-Jmstified, to another 
lO-character-long -working register (Rb) . 

The respective contents of registers Ra and Rb are compared, 
bit-position by bittposition. 

If the contents of the t-wo registers are identical in each 
of the 60-bit positions, then the next Instruction to be exfcmted -will 
be selected from the address specified bj Jj otherwise, the next Instruc- 
tion in sequence will be executed next. 



I\r-B-.3 



TABLE IV-1: Language Code 





NUMERIC 














NUMERIC BITS 














ZONE 


VALUE OF 




























BITS 


ZONE BITS 


0000 


0001 


0010 


0011 


0100 


0101 


0110 0111 1000 1001 


1010 


1011 


1100 


1101 


1110 


nil 
































00 







1 


2 


3 


4 


5 


6 7 8 9 


@ 


^ 


SPACE 


& 


• 


» 


01 


-\i ". 


— 


A 


B 


C 


D 


E 


F G H 1 


D 


A 


m 


n 





p 


10 




+ 


J 


K 


L 


M 


N 


P Q R 


% 


£ 


$ 


( 


) 


/ 


11 


'^...T.-'-.y. .*' 


♦ 


# 


S 


T 


U 


Y 


W X Y Z 


d 


s 


u 


Y 


w 


X 



TABLE IV-2: Modification of first word of Instruction by Index Register 



S-value 
4 
2 
1 



Sum 



A syllable modified 
T syllable modified 
J syllable modified 
Determines combination 
of syllables modified. 



S-values of syllables 



4 2 1 



If S = 0, no Index Register is used, and R is irrelevant. 



TABLE IV-3: Interchange of syllables in ^0 



(^00) before operation 



SR!Wp5!!H-H-H-M-H-!-H-I-H-H-Hi 



^l^^MS^^^^MM 



Q 



(^00) after operation 



no branch 



branch 



positive 
negative 






P 

J L 



Q © 2 



^:^j:j^^sja:^:^^^iji: 



m^^ 






P 

J L 



Q ® 2 
3 I . 



Q © 2 



J 



COUNT 

This Instruction combines the functions of several 
standard Processor operations within a single operation, and 
operates on the contents of any one of the 10 memory locations 
OOP through 0Q9 . 

The Instruction uses MDDIFT ADD to augment a selected 
field of one of these 10 cells, using as an augmenter the 
right-justified contents of the A-field named in the Instruc- 
tion. Then a selected 3~character field of the augmented cell 
is compared mth a 3-character Tester, which is part of the 
Instruction itself. The tested field within the augmented cell 
need have no relationship to the augmented field within that 
cell. 

If the two 3-character fields being compared W NOT 
contain the same address-tjrpe number, then the next Instruction 
to be execnted will be selected from a "branch" address speci- 
fied in the Instruction; if the tw© 3~Gharacter fields DO con- 
tain the same address-type number, then the next Instruction in 
the normal sequence will be exec^ed. 

OVERFLOW ALAHM ; Will not be set under any circumstances. 



I7-E-1 



INSTRUCTION FORMATs 



9 


8 


7 


6 


5 U 


3 


2. 

1 


1 
1 




• 


Op , a _ 


T i J 

- f, . "I-- -5 1 t 


■ ^- . \: 


V 


M 


S 


R 


At, Ar 


■ 


Ir Itr 


I 



Operation: COUNT (GNT) 
Operation Code : E 



DEFINITIONS: 

Op: operation code. 

M: auto-monitor level: 0, 1, 2, 3. 

S: designates syllables for modification 
by index-register OOR. 

R: designates OOR as index-register, 

A: base of address of quantity by which the designated 
field of cell 001 is to be augmented, 

Al;^ Ar: locations of left-most and right-most characteiTs, 
respectively, of the augmenter. 

I: • designates 001 as the cell whose contents are 
to be augmented. 

Ir: location of right-most character of the field of 
001 which is to be augmented. 

T: as modified by (OOR) , this is the Tester. 

Itr: location of right-most character of 3-character 
tested field of cell 001. 

J: base of address of next Instruction if T, as modified 
by (OOR) , and the tested field of 001 DO NOT contain 
the same address-type number, 

V: variation designator; 

only the sign of V is relevant. 



I7-E~2 



DESCRIPTION OFs COUHT 

This is a right-JTastified operation, consisting of two 
separate steps s 

1) MODIFY MBt (001: Ii-lR ) © [A] — ^ QOIs IlIr . It is not 
specified by the prograsnaer, since the Processor always adds to the 
9~Ir field of (OOR). 

2) COMPARES (OOIsItlItr) vs T. Itl is not specified by the 
prograimner, since the Processor always makes Itl= Itr + 2, and compares 
a 3~character field of (001). 

[A] is transferred, right- justified, to a 12~character-l©ng 
working register (Ra) . 

(OOl), from position 9 through position Ir, i.e., — liPOl] , is 
transferred, right-justified, to another 12-character-long working 
register (Rb), 

In the course of both these transfers, the zone-bits of the 
right-most two characters in each group of three are replaced by O-bits « 

"The contents of registers Ra and Rb are then added, using the 
special kind of addition described under MODIFY ADD , and the result is 
stored in a third 12-character-long working register (Re) » 

The contents of Re then replace [GO I) , right- justified. 

Mext, (OOI), from position 9 through position Itr, is trans- 
ferred:, right-justified, to a ^-^^haracter-long working register (Rd). 
The contents of the ^-character field in the first word of the Instruc- 
tiom (the field called T) are modified (if appropriate) by (OOR), and 
transferred, right-justified, to another 3-character-l0ng working 
register (Re). In the course of both these transfers, the zone-bits of 
the right-most two characters are replaced by 0-bitSo 

If, at this point, the contents of Rd and Re are identical, 
the next Instruction in the normal sequence will be executed next. If 
the contents of Rd and Re are not identical, the Instruction whose ad- 
dress is designated by J will be executed nexto 



OVERFLOW ALARM ; Will not be set by this Instruction. 



I?-E-3 



Examples- COUNT 

ExaTiple 1 - Double the quantity stored in field 86 of the 2nd word 
of each of ten 3-word items. Store the results in field 
63 of each of 10 words. 



THREE-WORD ITEMS 



INSTRUCTIONS 



700 
701 
702 
703 
704 
705 
706 
707 
708 
709 
710 
711 
712 
713 
714 
715 
716 
717 
718 
719 
720 
721 
722 
723 
724 
725 
726 
727 
728 
729 



9 8 7 6 5 4 3 2 10 



• I 'r'j f'" ' - I l | - I J-M I i i ' ' . ' I C j j. ' . ' , ' . ' . ' . ' Il l-" 



V i i.i.i.i.;.M.MX^vXO!0)!0!C!v!-!- ' - ' -^OXO!0!OXiii 



1 1 !*! ' . ' . V. I' l i r r , . I *'i'i ' iy' i'i'i'i«i'i'i III II J 



I i ! '! " " ' * * * * ' ' ' * ' ' i 1 1 III I ' l i i i 'ii i i ; i'i"i'i' i ' i ' i i j 1 1 1 1 ! 
|i mI i j I t ti I III III. /lYiYiiii 'i' i 'i'i' i 'i' i ' i'i'i'i'lV!'!'!'!'. '' ! ' 



'**;*;';''''*■*'*''''''■*•'■'■*■* 1 1 1 i !*! *!'!*!'! '!*!';';';';';';'; ';''-'-'!*! 'j 



•'''-'**'*'' ''''''''' I 'l*' ' " f"W I I i ''*'*'''*'''*''' ! i I i i i i I r T*'*'' 



! ' X ' XO!':!! ! !!^:^!•^ ' ^ ' ^^ ' AuXO!v! ' X'Ii!v^ ! •^ ' ^'•'XuXC 



XOXOX^^^i^!v!%X ' XOX ' XOXJ!•!^^!^ ! jS ^ ^ 



; i MM i' » 1 ' ' ! ■ ! ■ ! ' ! ■ ! ' ; »;' ; ■ ; I'l' i ililll!!! i ' l * l 

i' l i i'l 11 . . ■ ■ '. ' » » ' ■■ i ' i ' i i I'j I f;']'!*!*! '''*'''''''' ' ' ' I i I ■ I 



ffOXO!0!v!-!v!!-!-!-!JXwX'!vV-!-!.!-!!-!-!. ! JJ!'XC 






l^^OM ' XOX'XOjX^!v!v^'^ ' ^ ' X^OX ' XvXv!^^^^!^ 



!!■!■» ' « ! i Ti i 11 1 1 1 rr. l''y '' ! ''i < 'i' H i yiTi'f:"fl''''''''W ' i 'i 



' 'Xv! ' !v::-M' ' XwX(('XvX(v!-!-!- ' XOXO!OXO!0 



■,i,i ; ii ' i ' i ' ' i * ' I J I ill I i ^ ; « ; i ; i ; i ; i v i' i illl I ' ! ' ! ' ^ ' ! ' !'^ ''! ; ' ;!; 



iWjViViV i imYm i V.;.;.;.|;]jYm ^ ^ 
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273 


2 


2 


2|0 2 


274 





OlOfO 9 9 019 01 






275 


1 7 117 112 11 


276 





07 2 


8 6 8 616 31 






277 


¥ 


2 5 


10 


2-7 5 


278 








6 0^ 


o|o|:^ 



Clear location 002. 



Perform the addition. 

Select the operands relative to 002. 

Augment (002) and test for end. 



250 |;pi:iii3 3 11 Augmenter 



RESULTS OF ADDITIONS 




9876543 210 


201 


:SS|:|v$::^ 


2 4 8 


iiiS 


202 


§!:§¥•:*$$: 


2 




203 


•ryi'i'i'ivi"'*''"''' 


14 3 2 




204 




1116 




205 




10 4 




206 









207 


:?:W-?vSv;' 


8 8 




208 




9 2 2 




209 




9 




210 




2 14 





IV-E-4 



Example 2 - Same as Example 1, except: 

Perform the additions, starting at the bottom of the list 

of items. Store the simis, starting at the top of the 

list of results. Use a different method of clearing (002). 

INSTRUCTIONS 



273 
21U 

275 
276 

277 
278 



12 74 


2 7 4 21 


010 0888890 



172872 812 01 


0072868 616 3 



2 5 IZ 7 







8 0l;;|0|6i2 



2 7 5 



Clear location 002, 



Perform the addition. 

Select the operands relative to 002, 

Augment (002) and test for end. 



250 W2 9 7|Z 9 7|0 1 I Augmenter 



RESULTS 


OF ADDITIONS 




9876543210 


201 


::ii:i$^Sw 


2 14 


WmMi 


202 




9 


i:i:i:i::g:|:|:§:|::: 


203 


ii:ii$^$ 


9 2 2 


•rjSjijSjS^:© 


204 




8 8 




205 


SSi-S-Ssi^v 







206 




10 4 




207 


Wi';'x*:$i'i-S' 


1116 




208 


iiwSssjs? 


14 3 2 


^■$:'S:$;-:':SS 


209 


i-i-S-i-S§:S:? 


2 




210 


Ri^i; 


2 4 8 





It should be observed that (002) is being COUNTED "backward" in 
the A and B syllables, and "forward" in the C syllable. 



IV-E-5 



TABLE IV-1: Language Code 





NUMERIC 














NUMERIC BITS 
















ZONE 


VALUE OF 






























BITS 


ZONE BITS 


0000 


0001 


0010 


0011 


0100 


0101 


0110 0111 1000 


1001 


1010 


1011 


1100 


1101 


1110 


nil 


00 







1 


2 


3 


4 


5 


6 7 8 


9 


@ 


t 


SPACE 


& 


• 


» 


01 


->i --- 


— 


A 


B 


C 


D 


E 


F G H 


1 


D 


A 


m 


n 





P 


10 


■-:' '^ . 


+ 


J 


K 


L 


M 


N 


e P Q 


R 


% 


£ 


$ 


( 


) 


/ 


11 




♦ 


# 


S 


T 


U 


V 


W X Y 


Z 


d 


s 


u 


V 


w 


X 



TABL E IV-2: Modificati on of first word of Instruction by Index Register 

S-values of syllables 



S-value 
4 

1 



Sum 



N syllable modified 

J syllable modified 
Determines combination 
of syllables modified. 



4 

J L 



2 

J u 



1 

J L 



If S = O, no Index Register is used, and R is irrelevant. 



TABLE IV-3: Interchange of syllables in »00 



(^00) before operation 



w^. 



WmMmmmfm i i 



Q 

J L 



positive 
negative 



(^00) after operation 



no branch 



^^■Mitii^^: 



mi 






p 

J L 



Q e 2 

1 I . 



Q ® 2 



branch 



HWK-a:- : w- ! -H'.v':-Mj-M:H-::>:i!-y$i 



Q e 2 



J 

J L 



TEST 



This Instruction really embodies four different Instructions <, 

1) TEST Overflow , If any Instruction sets the Overflow Alarm, the 
Processor will immediately halt unless the next Instruction is TEST 
Overflow; in that case, the Overflow Alarm will be turned off^ and the 
next Instruction to be executed will be selected from a *'braneh** address. 

If the programmer anticipates that Overflow might 
occur, this feature permits him to provide for this exceptional case auto- 
matically, without requiring operator intervention during processings 

2) TEST Option Switch , This feature provides convenient facilities for 
permitting operator intervention during processing. If the designated one 
of ten Console Option Switches is ON, the next Instruction to be executed 
will be selected from a "branch" address. This feature is particularly 
useful for interrogating the files, or in permitting routine processing to 
be interrupted for high-priority work, 

3) TEST Reader Code. The High-Speed Paper-Tape Reader can read any 
three codes, with the particular code used being selected by a manual 
switch on the Console, This facility permits the Reader to be compatible 
with a wide variety of tape-punching devices. 

This variation of TEST assures that the operator 
has set the STET Code-Selection Switch properly, and also provides im- 
portant audit and protection facilities. 

Accounting Machines, recording monetaiy transac- 
tions, can punch a code incompatible with, for example, the code punched, 
by typewriters recording non-monetary transactions. Therefore, any at- 
tempt to simulate a monetary transaction with an unauthorized device can 
be detected immediately, 

^) "^ST Puncb -;.Cod© ^ .. The High'-Speed Paper-Tape Punch can punch any 
two codes, with the particular code used being selected by a manual 
switch on the Console, This facility permits the Punch to produce paper- 
tape which is compatible with tape-to-card .eoaverters, typewriters, tele-- 
graphic transmitters, &c. 

This variation of TEST assures that the operator 
has set the Punch Code-Selection Switch properly, for the operation to be 
performed. 



IV-P-1 



INSTRUCTION FORMAT; 

9 S 7 6 5 4 3 2 1 



Gp 



i-:-:-::-:^:-:::v:-:»::v:v:::::v:-:-^:;:r::j;:i 



J L. 



..£_ 



Operations TEST OVERFLOW (TEST; 
Operation Code? F (V = O) 



V 


M 


S 


R 


i;i:i;i±a-:v;v:>;-:^^ 



DEFINITIONS: 

Op: operation code. 

M: auto-monitor level: 0^ 1, 2, 3. 

S: designates syllables for modification 
by index- register OOR. 

R: designates, OOR as index register. 

J: base of address of next instruction if 
Overflow Alarm had been set by the 
preceding instruction. 

V: Variation designator; 

V = specifies TEST Overflow^ 



If the Overflow Alarm 
had been set, TEST 
Overflow turns it off. 



INSTRUCTION FORMAT: 



9 


8 

.: — 


7 

L... J 


6 


5 4 3 


2 


1 
( t » 


OP 




N 




, J ._„ 








V 


M 


s 


R 


iJiii^liiiiii^iiiiiiiSS-i-i-fti: 


ki'yi^Wiim- 



Operation: TEST OPTION SWITCH (TES|^; 
Operation Code ? F (V « 2 ) 



DEFINITIONS: 

Ops operation code„ 

M: auto-monitor level: 0^ 1, 2^ 3. 

S: designates syllables for modification 
by index-register OOR, 

R: designates OOR as index-register. 

N: as modified by (OOR) , specifies the 
number of the Console Option Switch 
to be tested. Switches are numbered 
from through 9. 

J: base of address of next instruction if 
the designated Option Switch is "ON". 

V: variation designator;' 

V = 2 specifies TEST Switch. 



Each Option Switch shows: 
Yellow light when ON. 
Blue light when OFF. 



The comparison is made 
against all four 
numeric bits of N« 



IV-F-2 



INSTRUCTION F0R14AT: 

98765432 10 



Op 


1 


N 


•:•:•:■;•:•!•;•:•:■!•:•:!;■!•!•!■:•!• 


1 1 




V 


M 


s 


R 


:::::::::::<:::;:::::::>:::::::::::t:::::::::::i:::::;x;::K::::::::v 



Operation: T^ST READER CODE (TESTsE] 

Operation Code: F (V « 4) 



DEFINITIONS: 

Op: operation code. 
M: auto-monitor level: 



0, 1, 2, 3. 



S: designates syllables for modification 
by index-register OOR. 

R: designates OOR as index register. 

N: as modified by (OOR), specifies the setting 
(O, 1, 2) of the Code-Selection Svritch for 
the High-Speed Paper-Tape Reader. 

J: base of address of next instruction, if the 
switch-setting is the same as specified by N 

V: variation designator | 

V = 4 specifies TEST Readier Code. 



The comparison is made 
against all four 
numeilc bits of N. 



INSTRUCTION FORMAT: 

9 8 7 6 5 4 3 2 1 



Op 


,,...t 


N 


r;.;.:;.....|.j;....;..A;..j;..> 

:;::-:':=:-:^-f-:-:-;-;¥;;;-;-;S 


1 1 

J 
1 



Operation: TEST PUNCH CODE (TEST:P) 
Operation Code: F (V» 6) 



V 


M 


S 


R 


M:iiM>kiMi<^!Mi:^^ 



DEFINITIONS: 

Op: operation code. 

M: auto-monitor level: 0, 1, 2, 3. 

S: designates syllables for modification 
by index-register OOR, 

R: designates OOR as index-register. 

N: as modified by (OOR), specifies the setting 
(O, 1) of the Code-Selection Switch for the 
High-Speed Paper-Tape Punch. 

J: base of address of next instruction, if the 
switch-setting is the same as specified by N, 

V: variation designator; 

V «= 6 specifies TEST P^nefc Co<i@* ^ 



The comparison is made 
against all four 
numeric bits of N. 



IV-F-.3 



TABLE IV-1: Language Code 





NUMERIC 














NUMERIC BITS 














ZONE 


VALUE OF 




























BITS 


ZONE BITS 


0000 


0001 


0010 


0011 


0100 


0101 


0110 0111 1000 1001 


1010 


1011 


1100 


1101 


1110 


nil 


00 


IH 





1 


2 


3 


4 


5 


6 7 8 9 


@ 


^ 


SPACE 


& 


• 


» 


01 


HIS 


— 


A 


B 


C 


D 


E 


F G H 1 


O 


A 


m 


n 


9 


P 


10 


mi 


+ 


J 


K 


L 


M 


N 


9 P Q R 


% 


£ 


$ 


( 


) 


/ 


11 


■II 


* 


# 


S 


T 


U 


V 


W X Y Z 


d 


s 


u 


Y 


W 


X 



TABLE IV-2: Modification of first word of Instruction by Index Register 



S-value 
4 
2 
1 



Sum 



A syllable modified 
B syllable modified 
C syllable modified 
Determines combination 
of syllables modified. 



S-values of syllables 



4 

J L 



2 

J L. 



If S = O, no Index Register is used, and R is irrelevant. 



TABLE IV- 3: Interchange of syllables in ^00 



(^00) before operation 







P 

1 1 


,Q, 


;. . i 


- »- '*■ ^■ 



V 


(^00) after operation 


positive 
negative 










: 




P 

1 I 


Q ® 2 




f; ; 


.♦ *- 












'V •''.»' 


Q.^.2 


P 




,,. 


'-.. ^. L.i'.....t. 









COMBINE 

The contents of the A~ and B-f ields are combined 
into a single field for the C-pmtaway. 

The B-field is put away first, from right to left; 
then the A~field is put away, from right to left, immediately 
to the left of the B-field put away. 

If the C -field is shorter than the combined A- and 
B-f ields, characters will be lost from the left end of the 
A-fieldo If the C-field is shorter than the B-field alone, 
then the entire A-field, and characters from the left end of 
the B-field, will be lost. 

If the C-field is longer than the combined A- and 
B-f ields, zejTos will be added at the left to fill out the 
put away field, 

OVERFLOW ALARM ; Will not be set under any circumstances . 



I?-H-l 



INSTRUCTION FORMAT t 

9S76 543^2 10 



Op a 

1 S 1 


B G 
It t . 




V 


M 


S 


R 


Al Ar 


Bl Br 

1 ., 


Cl Cr 



Operation J COMBINE (GcflB) 
Operation Code; H 



DEFINITIONS: 

Op: operation code. 

M: auto-monitor level: 0, 1, 2, 3. 

S: designates syllables for modification 
by index-register OOR. 

R: designates OOR as index-register. 

A: base of address of left-hand field. 

Al, Ar: locations of left-most and right-most 
characters of left-hand field, 

B: base of address of right-hand field. 

Bl, Br; locations of left-most and right-most 
characters of right-hand field. 

C; base of address into which the A- and 
B-fields -will be combined. 

Cl, Cr: locations of left-most and right-most 
characters of the combined field. 

V: variation designator; 

only the sign of V is relevant. 



IV-H-2 



DESCRIPTION OF: COMBINE 

This is a right- justified operation. 

Qb] is transferred, right-jmstified, to a 20-character- 
long working register (Re). Then QA] is transferred to Re, right- 
justified against the left-most character from CbJ. In the course 
of these transfers, all zone-bits are preserved, and the informa- 
tion is unchanged. 

The contents of Re then replace I^CT], right-justified. 

OTERFEOW ALARM: Will not be set* 



H-H-3 



Ekamfjles ^ --COIffi IM^ 



99g 7/6, 5 4 3 2 10 

342: wm^m2:^.9}^!im^m 



291:. ^^smmmF .6 ,7mm 



Example 1 



H 3.4.2 


2.9 1 0.5 








6.4 4.2 7.0 



005: mmO,0.2M,9,F ,6.7\ after 



Example 2 



3„4,^ 



© 



:^,a.^QtQ> ? 



6i4(4'2Ja::Q 



005: lippp ^^ ^^^^^ ^^^ ^^^^ after 



Example 3 



2,9,1 3.4.2I0.0.5 



0l0|0l4.2l6.4lB.3 



005: MF. 6. 7. 2 M. 9 mmm after 



IV-H-4 



TABLE IV-1: 



Language Code 





NUMERIC 














NUMERIC BITS 
















ZONE 


VALUE OF 






























BITS 


ZONE BITS 


0000 


0001 


0010 


0011 


0100 


0101 


0110 0111 1000 


1001 


1010 


1011 


1100 


1101 


1110 


nil 


00 
01 
10 


■ill 




+ 


1 

A 

J 


2 
B 
K 


3 
C 
L 


4 
D 

M 


5 
E 

N 


6 7 8 
F G H 
e P Q 


9 

1 
R 


@ 
D 
% 



A 
£ 


SPACE 

m 
$ 


& 

n 

( 


• 

8 
) 


P 
/ 


nil 


illll 


11 


!■ 


* 


# 


S 


T 


U 


V 


W X Y 


Z 


d 


s 


u 


v^ 


W 


X 



TABLE IV-2: Modification of first word of Instruction by Index Register 



S-value 
4 
2 
1 



A syllable modified 
B syllable modified 
C syllable modified 



S-values of syllables 



Sum Determines combination 

of syllables modified. 



4 

J L 



2 

J L. 



1 
J L 



If S == 0, no Index Register is used, and R is irrelevant. 



TABLE IV-3: Interchange of syllables in 0OO 



(^00) before operation 





. 




P 


. Q. 






; : 


» » r.; 










V 


(0OO) after operation 


positive 
negative 












-i *....'... 


P 

1 I 


Q^e 2 








Q ffi 


p 


1 — j 


"■■■ ■» * 


1 1 





Three INSTRUCTSONSj DISTRIBUTE, SUPPRESS, EDIT, ARE GENERALLY SIMILAR. BASICALLY, 
EACH OF THEM COPIES THE CONTENTS OF THE A-FIELD INTO THE B~ AND G-FIELDS*. THE C-POTAWAY IS WhBE 
FIRST, FROM RJ6HT TO LEFT; THEN THE B-POTAWAY IS MADE, FROM LEFT TO RIGHT, EACH IN^TRIJCTION «AS 
TWO VARIATIONS, AND EACH VARSATION CHANGES THE CONTENTS OF THE A-FIELD IN A DIFFERENT MANNER 
BEFORE MAKING THE POTAWAYS. 



DISTRIBUTE 

"Normal" Tariation g The contents of the A~field are unchanged 
in the pntaways. If either pmtaway field is shorter than the A-field^ 
characters will be lost in that putaway; if either ptitaway field is longer 
than the A-field, zeros will be added to fill o\it that putaway field, 

'■'Sign Split-4)f f " •srariatiom ; The s^gn of ' the A~fi6ld (designated 
by the 5th bit in the left-most character) is split off ^ and appears in 
the putaways as a separate character; a positive sign appears as a "space" 
character^ while a negative sign appears as a '*-" character^ immediately 
to the left of the character from which it was split ©ff . The zone-bits 
of all the original characters from the A-field are replaced by 0-bits in 
the pmtaways, leaving only the ntmeric bits in the B- and G-fieldSo 

The piataways^ therefore ^ are each one character longer than the 
A-field, If the G -field is longer than this, "space" characters will be 
added to the left of the sign character^ if it is the same length as the 
A-field^ the sign character is lost (once split off^ the sign is never re- 
combined with the left-most character); and if the G-field is shorter than 
the A-field.) other characters will be lost from the left end of the fieldo 
If the B-field is longer than the pmtaway^ zeros will be added at the 
right end of the field; if it is to© short for the full pmtaway^ characters 
will be lost from the right end of the field., 



OYEHFLOW ALARMS Will . mot be 'set by .either variation. 



If~J~l 



INSTRUCTION FORI^xAT; 



9 


8 


7 


6 


5 4 


3 


2 


1 

• 1 


Op 


^ A 
} 1 


B 


C 

t 1 




V 


M 


S 


R 


Al Ar 
1 


Bl Br 
1 


Gl Or 



Operation: DISTRIBUTE (DIST] 
Operation Code: J 



DEFINITIONS: ' 

Op: operation code. 

M: a-uto-monitor level: 0, 1, 2, 3. 

S: designates syllables for modification 
by index-register OOR. 

R: designates OOR as index- register. 

A: base of address of word containing the field 
whose contents are to be distributed. 

At, Ar: locations of left-most and right-most characters, 
respectively, of the A-field. 

B: base of address of location into which the 

distributed field is to be placed, left -justified, 

Bl, Br: locations of left-most and right-most characters, 
respectively, of the B -put away field. 

0: base of address of location into which the 

distributed field is to be placed, right -justified. 

Cl, Or:' locations of left-most and right-most characters, 
respectively, of the C-putaway field. 

V: variation designator: 



V 


Specifies 


Abbreviatiom 





Normal 


DIST 


1 


Sign Split-Off 


DISfgS 



IV-J-.2 



DESCRIPTION OFs DISTRIBUTE 

V = Q g [A^l is transferred to a 10-character-long working register (Re) ^ 
right-^imstif ied , and also to another 10- character-long working register 
(Rb), left-justified , In the comrse of these transfers, zone-bits are 
preserved j, and the information is imchangedo 

The contents of Re replace [C], right-jmstif ied ; then the con- 
tents of Rb replace [B^, left- justified ^ 

V = I s This is the "Sign Split-Off" variation. 

An 11-character-long working register {Re) ^ is filled with 
"space" characters, and then Qa] is transferred to Re, ri^ht-justif ied » 
[_Aj is also transferred to another previously cleared, ll^eharacter-long: 
wcMn. register (H.) ■ le.t-..sUneC at cHa^cter^osiUo. o *^ 

In the course of both these transfers, the zone-bits of all 
characters transferred are replaced by 0-bits« 

If the sign-bit of the character in position Al is a 1-bit 
(minus sign), then a "minus" character (code 01 OOOO) is inserted into Rb 
at character-position 10^ and into Re at the character position immediately 
to the left of the character transferred from position At. 

If the sign-bit of the dharacter in position At is a 0-bit (plus 
sign), then a "spaee" character (code 00 1100) is inserted into Rb at 
character-position 10« (Note that the corresponding character-position in 
Re already contains a "space" character, ) 

The contents of Re replace QO^ right-justified ; then the con- 
tents of Rb replace [b2^ left-justified » 

OVERFLOW ALAM g Will not be set by either variation , 



If»j-3 



DISTINCTIONS 



DISTRIBUTE, SUPPRESS, EDIT 



CA] 



00465 



Instruction V r- B -Put away 



C-Putaway 



9 



DISTRIBUTE |0 .0 .4 .6 .5 .0 .0 .0 | lO.O .0 .0 .0 .0 .0 .4 .6. 5 



DISTRIBUTE 1 Isp.O .0 A .6 ■ S ,0 .0 .0 .0| |spsp. sp . sp ,sp . o .Q ,4 ,6. 5 



SUPPRESS 



I SP.SP.4 .6.5.0.0.0.0 701 Isp.sp.sp .SP.SP.SP.SP.4 . 675 



SUPPRESS 1 lsP.sp.sp.4.6. 5.0.0.0.01 |sp.sp.sp.sp.sp.sp.sp.4.6.5i 



EDIT 



lsp.sp.4. 6.5.0.0.0.0.01 lo .0 .0 .0 .0 .0.0 .4 .6 .5 i 



EDIT 



1 M-.---A.6.S. 0.0.0. 0.Ol 10,0.0.0.0.0.0.4.6,5! 



-00009 DISTRIBUTE l-.O .0 .0 .0 .9 ,0 ,0 .0 .0 | JO .0 .0 .0 .-.0 .0 .0 .0.9 



DISTRIBUTE 1 l-.O .0 .0 .0 ,0 .9 .0 ,0 .01 jsp.sp.sp.-. .0.0 .0 .0 .0 . 



SUPPRESS 1~.SP.SP.SP.SP.9.0.0.0.0| jsp.sp.sp. sp.-.spsp sp sp 9l 



SUPPRESS 1 I-.SP.SPSPSPSP.9.0.0.0I jsp.sp.sp.- .sp.sp.sp.sp.sp. 9 



EDIT 



I -.sp.sp.sp.sp, 9, . 0,0,01 10.0.0.0.-. 0.0.0.Q.9 



EDIT. 



1 l^\-"'.'"."-.^S9.0.0 .0.0i iO.0.0.0 .0.0.0.0 .0.9 
Sets Overflow Alarm 



IV-J-4 



G26A9 



Instruction V ^ B-Putaway 



C 



C-Putaway- 



<r 



} 



DISTRIBUTE |G .2 .6 A .9 .0 .0 .0.0.0 I I 0. 0.0.0. C G. 2. 6. A. 9 



DISTRIBUTE 1 I-.7 .2 .6 .1.9.0.0.0.0| |sp.sp.sp.sp.~.7.2. 6.1. 91 



SUPPRESS 



I0.2.6.A. 9. 0.0. 0.0.01 ISP.SP.SP.SP.SP.G.2.6.A.9J 



SUPPRESS 



\ !-. 7.2. 6.1. 9.0.0. 0.OI ISP.SP.SP.SP.-.7.2. 6.1.9 



EDIT 



IO.2.6.A.9.0.0.0.0.0I lO.O.O .O.O.G.2.6.A.9 



EDIT, 



1 17.2 .6 .1.9.0,0.0.0.01 10.0.0.0.0.7.2.6.1.9 

Sets Overflow Alarm 



DISTRIBUTE lo.O .0 .0 .0.0. 0.0.0. Oj lO.O .0 .0 .0.0. 0.0.0. 0| 



DISTRIBUTE 1 |sp.O .0 .0 .0.0.0. 0.0. Ol |sp. sp.sp.sp.sp.sp.sp.sp.sp. Ol 



SUPPRESS Isp.sp.sp.sp.sp.sp.sp.sp.sp.spI jsp.sp.sp.sp.sp.sp.sp.sp.sp.sp 



SUPPRESS 1 Isp.sp. sp.sp.sp.sp.sp.sp.sp.sp! jsp.sp.sp.sp.sp.sp.sp.sp.sp.sp! 



EDIT spspspspspspsp sp spspI lOOOOOOOOOO 

' ' ' I I I I . i I I ' ' I 1 I 1 « < » I I 



EDIT 



1 l•^.^^•^7^^^^^^•^^•^^^.•^M lo.o.o.o.o.o.o.o.o.oi 



lv~j-.5 



"Normal" DISTRIBUTE is an extremely versatile Instruction for performing 
logical operations. The follovdng examples illustrate some of the 
techniques to v/hich it lends itself. 



Example 1 , Clear two fields of an Index Register 

9876543210 

371 
372 



J 3 7 2 


3 3 


000099B620 



9876543210 
372 1 jfm)MOM&BMMBM 



Rb 000000000 



9 B 7 6 5 4 3 2 10 
003 Before |0{A 7 6iO 5 9;? 6 3 



003 After m 



/>V 



iOiSi^i 



Re 



000 

c 



i 



Bxamnle 2 . Clear tv/o Index Registers . 
9B7 6. 543210 



BBS 


J 


B 8 7 


3 6 


B87 








9 919 0!9 



Rb 



!:zx 



9876543210 



B87 o ^MMqMMMqMM 



000000 0000 



9876543210 



003 Before 0B6 60193 4 5 



003 After 



0000000000 



Re 0000000000 


9876543210 






006 Before |G 762105287 








1 






006 After 0000000 00 





r/~j-6 



"Normal" DIST1"{IBUTS 



PliD.nt a Constant in the A and C fields of 00£|. 
Clear the B field of 00/.. 



9 


87 6 


5/^3210 


J 


8 


Z^ /^ 





000648650 



Rb 



98765 43 210 
800 |iqji;:B;;X:j7 6 7 ['91 cMJg:; 



7670000000 

=3 ' 



9 8 765 4 32 1 
004 Before fOjA 3 9!o 5 9;P 6 3 



L 



004 After i;gj(7 6 7;^0 0;7 6 7 



Re 



0000000767 

1==: 



Example 4 > Plant one Constant from 657 188 in 257^77 and 
another Constant from 657? 53 in 00 5? 86. 



9 8 7 6 


543210 


J 


6 5 7 


257005 








8 3 7 7 8 6 



9 8 7 65 4321 
657 [3161:11 A 3 iMMM 



Rb 


67 4A310000 






9876543210 


257 Before 


2 2;9|7 6 2 9 18 3 










i>,....i.v.>.r^ 


257 After 


ii2|2; 


^issiiiifflsi 



R 
9 


1 




c 0000674A31 


876543210 




005 Before 7! B 8 4:6 2 9 4 4 8 | 




J 










005 After E 


A 3 liiiiiyiii 



IV-J-.7 



"Normal" DISTRIBUTE 



Example 5 « Plant a Constant from 800:5^ in 607:30. 

Jump to Instruction stored in Cell 300, and set return link * 



499 
500 



9 


8 7 6 


5 4 3 2 10 


J 8 OU 6 7 


- 





9 2 5 3|3 



Rb 



9876543210 



800 3 0|;:7;|A 4 2 3 'mSi 



3007A42300 

__3 



9 8 7 6 5 4 3 2 10 
(^00 Before |0;0 0;7 6 2j4 9 9 



^00 After Si; i: P:|0 j 3 Qi 5 1 



execution, but before 
-V interchange 



Re 



003007A423 

, 



9876543210 



607 Before 6 5 2 T 4;8 X 2 9 



607 After ^IMMM^SM 



A 4 2 3 



<^00 After teMQ:! 5 1: 3 
-V interchange 



m^^B 



"Normal" DISTRIBUTE 

Example 6a « Three Constants (X, Y, Z) are stored in Cell 800. 

Plant Y in the A and C fields, and Z in the B field, of Cell 300. 



9 8 7 6 


5 4 3 2 10 


J 


800300300 








5 2 8 3 



800 



9876543210 

T 



^QggM jA 2 7; 6. 3 5 



X 



Rb 



A 2 7 6 3 5 OOP 

=3 — ■ 



9 8 7 6543210 
300 Before lOlG 4 8!R 1 6^0 9 3 



300 After p| A 2 7j6 3 5j A 2 7 



Re 



000OA27635 



Example 6b . The same three Constants (X^ Y, Z) are stored in Cell 800. 

Pla.nt X in the A and B fields, and Z in the G fields of Cell 76I . 



9876543210 


J 


8 


761761 





0|0|0 


8 0|5 3 S 



Rb 



9876543210 



800 



M 


B 9 6 


mm ^ 3 5 



X 



B96A2763 50 



Re 



0B96A27635 

— r:" - 



761 Before 



9 8 7 


6 


543210 


w;f 9 


2 


2 8!9 



761 After C-putav/ay i. ., .; -j— — , 

but before B-putaway tlJB 9 6iA 2 7:6 3 5 



X 



761 After B-putaway [|jJB 9 6;B 9 6i6 3 5 



X 



X 



IV-.J-.9 



"l©rml'* DISmiBlJIi 



Exajgple 7 « IV/o-v/ay alternator. 

Interchange the A and C fields of Cell 6I9 > 



9^ 7 6 


5 4 3 2 10 


J 


6 19 


6 19 6 19 





OJO 


8 2 8 6 



619 Before :2[i 



9 8 7 6 5 4 3 2 10 
W 5 5 |iScIF2"8] 



Rb 



W55300R280 



, — c 



Re 



W 5 5 3 R 2 a 

^- ■ ^T= 



9 8 716 5 4 3 2 1 



619 After -^ The first time fe;JR 0|;;3|'aiQ!v/"5"5: 



J 



The next time this instruction PWrrT^WW^^^T^^^^Tls 
IS executed, (619) will becane: ^— =* — - ^- ■'■•'•■••••^ — 



and so on 



I7-J-10 



"Normal" DISTRIBUTE 



Example 8a . Three-v/ay alternator . Cycle the A,<— B,-e-C fields of Cell 574 ' 



9 8 7 6 


5 4 3 2 10 


J 5 7 4 5 7 4 5 7 4 


0000802083 





9 8 7 6 5 


4 3 2 10 




574 Before ^ 


1 2;1 3 2:2 1 4 












01213221/^0 Re 1 2 1 3 2 2 1 4l 






V .1 




9 8 7 6 


5 4 3 2 10 



Rb 



574 After — The first time 



1 3 2;2 1 4 '0 1_^ 



The second time this instruction 
is executed, (574) will become: 



2 1 4:0 1 2;1 3 2 



The third time this instruction 
is executed, (574) will become: 



1 2II 3~2l2lT 



— and so on 



Example 8b . The following Instruction will cause the three fields 
to C3rcle in the opposite direction; 



9 


876 


5 4 3 2 10 


J 


? 7 4 


5 7 4 5 7 4 





01 


8 01 5 8 6 



IV~J-11 



"Normal" DISTRIBUTE 



Example 9 » Tv/o-v/ay branchin/?: alternator , 

Write an Instruction in Cells 4B6-487 so that: Every other time it is 
executed, the program will select its next Instruction alternately from 
Cell 4S8 and Gell'^B73. 



484 r^ 

485 ^-^ 



486 
487 



488 Q 




489 



Alternator 



B73 
B74 




9 


876543210 


J 


962487(^00 





000905420 



9 8 


7 


6543 


2 10 


7 3 


9 


B 7 3 4 8 8 



486 
487 



962 



Initially, the Instruction picks up (962:90). 

The first time it is executed, it plants 
488 in <f,00;20, and chan ges itself so that 
the next time it is executed, it \d.ll 
pick up (962:73). 



The second time it is executed, it plants 
B73 in ^00:20, and changes itself so that 
the next time it is executed, it \'/ill 
pick up (962:90) again. 



IV-J-12 



"Normal" DISTRIBU: 



Example 10 . Five~v/ay branching alternator « Set return link . 

V/rite an Instruction in Cells F44-F45 to set up a 5-V'ay cj^-cle . After 
executing this Instruction, the program will select its next Instruction 
as follavs: 

1st time: from Cell F/i.6 

2nd time: from Cell A19 and link to Cell F91 
3rd time: from Cell A19 and link to Cell F93 
4th time: from Cell 766 and link to Cell F93 
5th time: from Cell G66 and link to Cell H23 

6th time : from Cell F46 again 
- - - and so on - - - 



The last Instruction in each branch X'/ill return to the proper point in 
the main program by using "minus V" . 

F42A 

F43 V 

F44 
P45 



F44 
F45 



F46/^ 
F47V>' 



5-way Alternator 



F91 
F92 



F93 
F94 



H23^ 
H24W 





603 
80 



'10 



9876543210 


IjlH 93F44*0 0| 


[0 


0|0|0 


8 018 6 5 01 



G66A 
G67V>J 



S@ 



9 8 7 6 5 4 3 


2 10 




H 9 4 




F 4 6 




H 9 5 


F 9 1 


A 1 9 




H 9 6 


F 9 3 


A 1 ? 




H 9 7 


F 9 3 


7^6 


UkU 


H 9 3 


H 2 3 


G 6 6 



H93 
H94 
H95 
H96 

H97 



Each time the Instruction is 
executed, it plants a pair of 
addresses in 000:53 and (^00:20} 
and changes itself so that the 
next time it is executed, it will 
pick up the next line of the table. 



IV-J-.13 



"Normal" DISTRIBUTE 

Example 11 « Self-re setting Program Sv/itch , 

Instruction A will normally cause the program to pass to Instruction B, 
Hov/ever, after Instruction C has been executed. Instruction A will: 

1) Cause the program to branch to Instruction D; 

2) At the same time reset itself to the normal condition • 




'^91 /m Self-resetting 



switch . 



BRANCH AND RESET 




COUNT 



H39/:irNGo to 073; 



D40P) 



\^ 



H40Vi;set 



A for branch. 



© 
© 



G91 
G92 

H39 
H40 



286 



9 S 7 6 


5 4 3 


2 10 


J 


2^7 


(^ 0|2 8 7 








502053 




J 


2 8 6 


2 8 71^00 








5 5 3|2 


9B 76543210 


'•:;:::::;:;:;:;:;;-;-^;j;v;|: 


D 3 8lG 7 3 


:-:':-:'x':-Sxv:-:^'-:- 


G 9 3 


G 9 31 



After Instruction C has been executed, 
287:53 contains D38. The next time 
Instruction A is executed, it plants 
D38 in (fi00i20, and resets (287:53) 

back to G93 . 



Alternate Method 



© 



G91 
G92 



\2J H40 



9 8 7 6 


543210 


J 


570*00092 





oTo" 


9 2 0|5 5 




J 


5 7 1 


G 9 2 ($ 





000] 


8 5 5 5(2 



9 8 7 6 5 


4 3 


2 10 


G 9 3|T) 3 


8 m 




m 6 G 7 3 







570 

571 



After Instruction G has been executed. 
Instruction A has been set to pick up 
(570:60). The next time Instruction A 
is executed, it v/ill plant D38 in 
^00:20 and if ill reset itself to pick 
up (570:90). 



IV-J-.I4 



TABLE IV-1; 



Language Code 





NUMERtC 














NUMERIC BITS 














ZONE 


VALUE OF 




























BITS 


ZONE BITS 


0000 


0001 


0010 


0011 


0100 


0101 


0110 0111 1000 1001 


1010 


1011 


1100 


1101 


1110 


nil 


00 


III 


1 





1 


2 


3 


4 


5 


6 7 8 9 


@ 


^ 


SPACE 


& 


• 


» 


01 

10 


11 


1 • 


+ 


A 
J 


B 
K 


C 
L 


D 
M 


E 
N 


F G H 1 
e P Q R 


D 

% 


A 

£ 


m 
$ 


n 

( 


9 
) 


P 

/ 


tili 


I 


11 


ilii 


i 


* 


# 


S 


T 


U 


V 


W X Y Z 


d 


s 


u 


Y 


W 


X 



TABLE IV-2: Modification of first word of Instruction by Index Register 



S-value 
4 
2 
1 



A syllable modified 
B syllable modified 
C syllable modified 



S-values of syllables 



Sum Determines combination 

of syllables modified. 



2 

J L. 



1 
J L 



If S = O, no Index Register is used, and R is irrelevant. 



TABLE IV-3: Interchange of syUables in ^00 



(«00) before operation 







f 1 ^ 


P 

1 • 


. Q. 










V 


(000) after operation 


positive 
negative 














P 


Q_® 2 




















^. '.« * ': 


Q e 2 
1 I 


P 











THREE INSTRUCTIONS, DISTRIBUTEj SUPPRESS, EDIT, ARE GENERALLY SIMILAR, BASICALLY, 
EACH OF THEM COPIES THE CONTENTS OF THE A-FIELD INTO THE B- AND C-FIELDS, THE C-RITAWAY IS 8IA0E 
FIRST, FROM RIGHT TO LEFTJ THEN THE B-PUTAWAY IS MADE, FROM LEFT TO RIGHT^ EACH INSTRUCTION HAS 
TWO VARIATIONS, AND EACH VARIATION CHANGES THE CONTENTS OF THE A-FIELD IN A DIFFERENT MANNER BEFORE 
MAKING THE PUTAWAYS, 



SUPPRESS 

"Nonnal" variation : The contents ot the A-field are zero-» 
suppressed in the B- and C-putaways; the character "-" is treated in a 
special manner, as it is not suppressed (replaced hj "space") > yet zero- 
suppression resumes to the right of a "-** character. If either putaway 
field is shorter than the A-field, characters will be lost in that put- 
away. If the C-field is longer than the A-field, "space" characters will 
appear at the left; if the B-field is longer than the A-field, zeros will 
be added at the right (unless the A-field contains all "zeros", in which 
case the B-field will be filled out to the right with "space*' characters). 

"Sign Split-Off" Tariation ; The sign of the A-field (designated 
by the 5th bit in the left-most character) is split off, and appears in 
the putaways as a separate character; a positive sign appears as a "space" 
character, while a negative sign appears as a "-" character, immediately 
to the left of the character from which it was split off. The zone-bits 
of all the original characters from the A-field are replaced by 0-bits, 
leaving only the numeric bits, and the putaways are zero-suppressed. 

The putaways, therefore, are each one character longer than the 
A-fieldo If the C-field is longer than this, " space" characters will be 
added to the left of the sign character; if it is the same length as the 
A-field, the sign character is lost (once split off, the sign is never 
re-bombined with the left-most character) ; and if the C-field is shorter 
than the A-field, other characters will be lost from the left end of the 
field. If the B-field is longer than the putaway, zeros will be added at 
the right (unless the A-field contains all "zeros", in which case the 
B-field will be filled out to the right with "space" characters); if it 
is too short for the full putaway, characters will be lost from the right 
end of the fields 

OVEHFLQW ALARM ? Will not be set by either variation. 

I?-K-l 



INSTRUCTION FORMT: 

9 876543210 



Op 


1 1 




1 .1 




V 


M 


S 


R 


Al Ar 
1 


Bl Br 

• 


a cr 

1 



Operation; SUPPRESS (SUPP) 
Operation Code? K 



DEFINITIONS: 

Op: operation code. 

M: auto-monitor level: 0, 1, 2, 3. 

S: designates syllables for modification 
by index- register OOR. 

R: designates OOR as index-register. 

A: base of address of word containing the field 
whose contents are to be distributed. 

Al, Ar: locations of left-most and right-most characters, 
respectively, of the A-field. 

B: . base of address of location into which 
the distributed field is to be placed, 
left -justified . , 

Bl, Br: locations of left-most and right-most characters, 
respectively, of the B-putaway field, 

C: base of address of location into which 
the distributed field is to be placed, 
right -.1 us tif ied . 

Cl, Cr: locations of left-most and right-most characters, 
respectively, of the C-putaway field. 

V: variation designator: 



V 


Specifies 


Abbreviation 





Normal 


SUPP 


1 


Sign Split-Off 


SUPP?S 



I7-K-.2 



DESCRIPTION OFs SUPPRESS 



V = ; QaI is transferred to a lO-character-long working register (Re) ^ 
rlght-.ius tif ied , and also to another lO-character-long working register 
(Rb) « left-1-Qstified o In the cotirse of these transfers^ zone-bits are 
preserved, and the information is unchanged. 

The contents of registers Re and Rb are then zero-smppressed| 
that is^ starting at the left end of each register^ all "zero" characters 
are replaced by ^space" characters (code 00 llOO), imtil a non-zero 
character is encountered^ or mitil all the characters in the register have 
been replaced by spaces. For the purpose of this variation ^ the character 
"-" is considered neither a zeroj, nor a non-zero character; it is not re- 
placed by "space" 3 nor does it teiiainate zero-suppression „ 

The contents of Re replace [cHj right-justified ; then the con- 
tents of Rb replace [b2$ left-justified „ 

¥ = I s This is the "Sign Split-Off" variation. 

La] is transferred to an ll-character-long working register (Rc)^, 
right-justified , and also to another 11-eharacter-long working register 
(Rb) , left- justified at character-position % In the course of both these 
transfers J the zone-bits of all characters transferred are replaced by 
O-bits 

The contents of registers Re and Rb are then zero-suppressed^ 
that is J starting at the left end of each register^ all "zero" digits are 
replaced by "space" characters (code 00 1100) j, until a non-zero digit is 
encountered 5 or until all the characters in the register have been replaced 

by spaces* 

If- the sign-bit of the character in position At is a 1-bit 
(iidnus.. sign)^ then a "lainms" character (code 01 OOOO) is inserted into Rb 
at .character-position 10^ and into Re at the character-position inmediately 

to the left of the character transferred from position At« 

If the sign-bit of the character in position At is a O-bit (plus 
sign) 5 note that the proper character-positions of registers Re and Rb 
already contain "space" characters,, 



The contents of Re replace LGJ^ right- 1 ust if i ed t then the con- 
tents of Rb replace CbX left-justifiedo 



0¥ERFLOW ALARMS Will not be set by either variation. 



I?=-K«.3 



DISTINCTIONS 



DISTRIBUTE, SUPPRESS, EDIT 



CA] 



00465 



Instruction V r- B-Putaway 



C-Putaway 



9 



DISTRIBUTE lO .0 .4 .6 .5 .0 .0 .0 1 1 0.0.0,0,0.0.0 . 4,6 . 5 .) 



DISTRIBUTE 1 Isp.n .0 A .6 .6 .0 .0.0 .0| | sp sp sp . sp . sp.O . . 4 .6. 5 . 1 



SUPPRESS 



lsp.sp.4.6.5.0.0.0.0.01 |sp.sp.sp.sp.sp.s p.sp.4.6.5l 



SUPPRESS 1 lsp.sp.sp.4.6.5.0.0.0,0 



sp.spsp.sp.sp.sp.sp.4.6.51 



EDIT 



lsP.sP.4.6.5.0.0.0.0.0{ |0. 0.0.0.0. 0.0.4. 6, 51 



EDIT 



1 h--/»-.A.6.^.0.0.0.0.0i 10,0.0,0,0,0,0.4.6^ 



-00009 DISTRIBUTE l~ .0 .0 .0 .0 .9 .0 .0 .0 ,01 |0 .0 .0 .0 .- .0 .0 .0 .0 .91 



DISTRIBUTE 1 i- .0 .0 .0 ,0 .0 .9 .0 .0 .0 1 |sp.sp.sp.~ .0 .0 .0 .0 .0 .9 



SUPPRESS | -.sP.sp,sp . sp . 9 . 0,0 , 0, 0| !sp.sp.sp.sp.~.sp.sp.sp.sp.9| 



SUPPRESS 



1 i-.sP.sp.sp.sp.sp. 9.0.0.0! |sp.sp.sp.~.sp.sp.sp.sp.sp.9 



EDIT 



i~.sp.sp.sp.sp. 9.0.0.0.01 lO. 0.0.0 .--.0.0.0.0.91 



EDIT. 



1 M--.^-. -"-.--- /--■9.0. 0.0. 01 10.0.0.0.0.0.0.0 .0.9 
Sets Overflow Alarm 



H-K-4 



G26A9 



Instinction V ^ B -Put away 



C 



C-Puta-way- 



<- 



3 



DISTRIBUTE |G .2 .6 A .9 .0 .0 .0 .0 .0 1 | 0. 0.0.0. 0. G. 2. 6. A. 9 



DISTRIBUTE 1 I-.7.2 .6 .1.9.0 .0 .0.0| [sp.sp.sp.sp.-. 7.2 . 6.1. 9 



SUPPRESS Ig.2.6.A.9.0.0.0.0,0| |sp.$psp.sp.sp.G.2. 6.A."9 



SUPPRESS 1 I~;7.2.6.1.9.0.0.0.0| |sp.sp.sp.sp.~.7.2. 6.1, 9 



EDIT 



|G. 2. 6.A. 9.0.0.0.0. 01 |0 . 0,0 . 0,0 . G.2,6 . A . 9 



EDIT, 



Sets Overflow Alarm 



1 17.2.6.1.9.0.0.0.0.01 10.0.0 . 0.0 . 7.2.6.1 . 9 



DISTRIBUTE Iq.Q .0 .0 .0.0. 0.0.0. 0| JO.0 .0 .0 .0.0.0 .0.0.0 



DISTRIBUTE 1 |sp.0 .0 .0 .0.0,0.0. 0.Ol |sp.sp.sp.sp.sp.sp.sp.sp.sp.O 



SUPPRESS 



Isp.sp.sp.sp.sp.sp.sp.sp.sp.spI |sp,sp,sp,sp.sp,sp.sp.sp,sp,sp 



SUPPRESS 



1 s p.sp.sp.sp.sp.sp.sp.sp.sp.sp sp sp sp sp sp sp sp sp sp sp 

' ' ' ' ' ' ' ' ■ ■' ' ■ ' ' '— ' ' I 1 1 1 _J I ■ ' ■ I 



EDIT 



^ pPSP.spspsp.spsp.sp.spspj jO, 0.0. 0.0. 0.0. 0.0.0 



EDIT 



]_ •}(- 4?- -)(- ■}(- -}(- -if- ■>(- i,'c •«• •}(- 
I I ' — »— J — I — 1 I ■ ■ 



o.o.o.o.o.o.o.o.o.oi 



IV-K-5 



TABLE IV-1: Language Code 



ZONE 
BITS 


NUMERIC 
VALUE OF 
ZONE BITS 


0000 


0001 


0010 


0011 


0100 


0101 


NUMERIC BITS 
0110 0111 1000 1001 


1010 


1011 


1100 


1101 


1110 


nil 


00 
01 
10 
11 


III 


illl 




+ 
* 


1 

A 
J 

# 


2 
B 
K 
S 


3 
C 
L 

T 


4 
D 
M 
U 


5 
E 
N 
V 


6 7 8 9 
F G H i 
9 P Q R 
W X Y Z 


@ 
D 
% 
d 


A 
£ 
s 


SPACE 

m 

$ 

u 


& 

n 

( 

V 


• 

e 
) 
w 


1 

P 
/ 

X 


III 


III 


III 


ill 


ill 


ill 


{Sgiiig;. 





TABLE IV-2: Modification of first word of Instruction by Index Register 



S-value 
4 
2 
1 



Sum 



A syllable modified 
B syllable modified 
C syllable modified 
Determines combination 
of syllables modified. 



S-values of syllables 



4 

J L 



2 

J L. 



1 
J L 



If S = O, no Index Register is used, and R is irrelevant. 



TABLE IV-3: Interchange of syllables in ^00 



(000) before operation 





■ 


i » ' 


p 

1 1 


. Q. 










V 


(000) after operation 


positive 
negative 












..* -»• '■■■ 


p 


Q ® 2 

1 1 




















^. ^» * 


Q © 2 

1 1 


p 

■ 1 











Three Instructions, DISTJ^IBUTE, SUPPRESS, EDIT, are generally similar. Basically, 

EACH OF THEM COPIES THE CONTENTS OF THE A-FIELD INTO THE B- AND C-FIELDS. TOE C-PUTAWAY IS MADE 
FIRST, FROM RIGHT TO LEFTJ THEN THE B-PUTAWAY IS MADE, FROM LEFT TO RIGHT. EACH INSTRUCTION KAS 
TWO VARIATIONS, AND EACH VARIATION CHANGES THE CONTENTS OF THE A-FIELD IN A DIFFERENT MANNER BEFORE 
MAKING THE PUTAWAYS. 



EDIT 

"Mo3rinal" variation : The contents of the A-field are unchanged 
in the G-prntaway, and are zero-suppressed in the B-putaway. In zero- 
suppression, the character "-" is treated in a special manner, as it is 
not suppressed (replaced by "spaced, yet zero-suppression resumes to the 
right of a "-" character. If either putaway field is shorter than the 
A-field, characters will be lost in that putaway; if either putaway field 
is longer than the A-field, zeros will be added to fill out that putaway 
field (unless the A-field contains all "zeros", in which case the B-field 
will be filled out to the right with "space" characters). 

"Dollar-Protection" variation : The zone-bits of all the 
characters from the A-field are replaced by 0-bits, leaving only the 
numeric bits. The G-putaway is made in that form, while the B-putaway is 
"dollar-protected"; that is, the B-field is zero-suppressed in the usual 
manner, except that ***"" characters (rather than "space" characters) re- 
place suppressed zeros. 

0¥ERFLO¥ ALARM : ' Will not be set by the "Nomal" variation. 

Will be set by the "Dollar-Protection" variation if any 
character in the A-field contains a 1-bit in any zone-bit position, in- 
cluding the sign-bit position of the field. 



If-L-1 



INSTRUCTION F0RI4AT: 



9 


8 


7 


6 


5 4 


3 


2 

■ 


1 

1 » 


Op 


,A. 


B 
• < 


.c. 




V 


M 


S 


R 


Al Ar 
1 


Bl Br 
1 


Cl Cr 

»- 



Operation: EDIT (EDIT). 
Operation Code: L 



DEFINITIONS: 

Op: operation code. 

M: auto-monitor level: 0, 1, 2, 3. 

S: designates syllables for modification 
by index-register OOR, 

R: designates OOR as index-register. 

A: base of address of word containing the field 
whose contents are to be distributed. 

Al, Ar: locations of left-most and rightnfnost characters, 
respectively, of the A-field. 

B:. base of address of location into which 
the distributed field is to be placed, 
left -justified . 

Bl, Br: locations of left-most and right-most characters, 
respectively, of the B-putaway field. 

C: base of address of location into which 
the distributed field is to be placed, 
right - justified. 

Cl, Cr: locations of left-most and right-most characters, 
respectively, of the C-putaway field. 

V: variation designator: 



V 


Specifies 


Abbreviation 





Nonnal 


EDIT 


1- ■' 


Dollar-Protection 


EDIT:P 



IV-L-2 



DESCRIPTION OF: EDIT 

? = Q s [X] is transferred to a IG-character-long working register (Re) , 
right-.jmstif ied , and also to another IO-character~long working register 
(Rb), left-.justified . In the course of these transfers, zone-bits are 
preserved, and the information is tmchanged. 

The contents of Rb are then zero-smppressed; that is, starting 
at the left end of the register, all '*zero" characters are replaced by 
"space" characters (code 00 llOO), luitil a non-zero character is encomn^ 
tered, or until all the characters in the register have been replaced by 
"spaces" o For the pmrpose of this variation , the character "-" is con- 
sidered neither a zero, nor a non-zero character; it is not replaced hj 
"space"., nor does it terminate zero-suppression. The contents of Re are 
not Ranged* 

(Re) replaces Qc], right-.jmstif ied ; then (Rb) replaces C^J, 
lef t-jmstif ied , 

V ° 1 ? This is the "Bollar-Proteetion" variation. 

Ea] is transferred to a lO-eharacter-long working register (Re) , 
right-justified „ and also to another lO-character-long working register 
(Rb), left-justified . 

In the course of both these transfers, the zone-bits of all 
characters transferred are replaced by 0-bits. 

The contents of Rb are then zero-suppressed and "dollar-protected"; 
that is, starting at the left end of Rb, all "zero" digits are replaced by 
"•^" characters (code 11 OOOO), until a non-zero digit is encountered, or 
until all the characters in the register have been replaced by asterisks. 
The contents of Re are not changed, 

(Re) replaces QcJ, right- jus tified ; then (Rb) replaces QbJ, 
left-justified . 



OITBRFLQW ALARM s Will not be set by the "lomal" variation (¥ = O) . 

Will be set by the "Dollar-Protection" variation (¥ = l) 
if any character in QAJ contains a 1-bit in any zone-bit position. 
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DISTINCTIONS 



DISTRIBUTE, SUPPRESS, EDIT 



CA] 



00465 



Instruction V ^ B -Put away 



DISTRIBUTE 



C-Putaiway 



9 



I0.0.4.6.5.QO 0.0.^1 lo.o.o.o.o.Q.0.4.6.5 



DISTRIBUTE 1 Isp.O .0 A .6.6 .0 .0 .0 .0| | spsp.sp . sp . sp,0 , . 4 . 6 . 5 



SUPPRESS 



lsp.sp.4.6.5.0. 0.0.0. 01 |sp.sp.sp.sp.sp.sp.sp.4.5,5| 



SUPPRESS 



T lsp:sP.sP./t.6.5.0.0.0.0| |SP,SP.SP.SP,SP.SP,SP 



[33II1 



EDIT 



lsP.sP./i..6.5.0.0.0.0.0l 10.0.0 , 0.0 . 0.0.4.6 , 51 



EDIT 



1 h^^-A.6.^.0.0.0.0.0l |0,0 .0.0 .0.0.0 .4_.6^ 



-00009 



DISTRIBUTE l~.0 .0 .0 .0 .9 .0 .0.0 .0 I lO.O .0 .0 .-.0 .0 .0 .0 .9 



DISTRIBUTE 1 h.O.O ,0 .0 ,0 . 9 .0 ,0 .0 | Isp.sp.sp.- .0.0 .0 .0 .0 .9 



SUPPRESS 



I--.SP.SP.SP.SP.9.0 .0.0 .01 |sp.sp.sp.sp.~ .sp.sp.sp.sp. 9 



SUPPRESS 



1 I--.SP.SPSPSPSP.9.0.0.0I |sp.sp.sp.~ .sp.sp.sp.sp.sp^ 



EDIT 



I -.SP.SP.SP.SP. 9.0.0.0.01 lO.O.O.O .-.0.0.0 .0.9 



EDIT 




^^9. 0.0.0. 01 I0.0.0.0.0.0.0.0.0.9 

Sets Overflow Alarm 



IV-.L-.4 



G26A9 



Instruction V ^ B-Putaway 



c 



C-Putaway- 



<r 



) 



DISTRIBUTE |G .2 .6 A ,9 ,0 .0 ,0 .0 ,0 I I 0. 0.0.0.0. G. 2. 6. A. 9 



DISTRIBUTE 1 I -.7 .2 .6 ,1 . 9 .0 .0 .0 .01 1sp.sp.sp.sp.~.772. 6.1. 9 



SUPPRESS IG.2.6.A.9.0. 0.0. 0.01 Isp.sp.sp.sp.sp.G. 2. 6. A. 9 



SUPPRESS 



1 U.7. 2. 6.1. 9. 0.0.0. 01 |sp.sp.sp.sp.~.7.2.6.1.9 



EDIT 



|G.2.6.A.9,0.0.0.0.0| lO.O.0 .0.0.G.2,6.A.9 



EDIT, 



1 17.2.6 ■1.9.0,0.0.0.0| 10.0.0.0.0.7.2.6.1.9 
Sets Overflow Alarm 



DISTRIBUTE lo.Q .0 .0 .0.0. 0.0.0. Ol JO.0 .0 .0 .0.0.0.0 .0.OJ 



DISTRIBUTE 1 |sp.0 .0 .0 .0 .0 .0.0.0.01 |sp.sp.sp.sp.sp.sp,sp.sp.sp.O 



SUPPRESS 1sp.sp.sp.sp.sp.sp.sp.sp.sp,sp1 jsp.sp.sp.sp.sp.sp.sp.sp.sp.sp 



SUPPRESS 1 jsp.sp.sp.sp.sp.sp.sp.sp.sp.sp! jsp.sp.sp.sp.sp.sp.sp.sp.sp.sp 



EDIT 1 sp sp.sp.sp sp sp sp ,sp,sp.sp| jO.O.O ,0.0.0.0.0.0.0 



EDIT 



1 -a- -X- -X- -X- -jc- ■iir -)(- -;(- -x- -*-^- 



jo. 0.0,0. 0.0. 0.0. 0.0 
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AN EXAMPLE OF EDITING 
Required: To edit a one-line Dividend Check and Stub 
Using COMBINE; DISTRIBUTE (V=0); SUPPRESS (V=0); EDIT (V=0, V=l); MOVE. 



RATE 




NAME 




No. SHARES 




AMOUNT 


•— •■ 1 — ' ■ 
1 


RATE 


No. SHARES 


AMOUNT 


6.00 




JAMES J DOE 




150 




$***900.00 




6.00 


150 $***900.00 





















V. 



_yv. 



DIVIDEND CHECK 



-~N/- 

CHECK STUB 



J 



START 



CLEAR 

PRINT LINE 

TO "SPACES" 




SUPPRESS: "O" -> 762:90 and 763:90 fP/anf ''spozQS." in 762 and 763) 
MOVE: (763), 10 WORDS -> 764 (Plant "spaces" in complete print line) 



762 I 763 I 764 
98765 4 3 210 9 876543210 9 876543210 



765 
98765432 1 



766 
987654321 



767 I 768 
98765 432 10 9876543210 



769 
987654321 



9 



m 



PRESET 




1 20-CHARACTER PRINT- LINE IMAGE 
SHADED AREAS REPRESENT "SPACE" CHARACTERS PLANTED BY THE PREVIOUS OPERATIONS 



DISTRIBUTE: "DECIMAL POINT" -> 762:88 and 767:99 (Plant decimal points) 
EDIT: DIVIDEND RATE ->> 762:99 and 762:76 (Plant dividend rate in check) 
DISTRIBUTE: (762:96) -> 768:96 and )z!09:90 (Plant dividend rate in stub) 
DISTRIBUTE: "$" -> 766:66 and (!^09:90 (Plant dollar sign in check) 



762 
987654321 


763 764 
98765432 1098765432 10 


765 
98765 4 3 


21 


766 767 
987654321 0987654321 


768 
9876543210 


. 769 
987654321 


9 


6.00 










$ 


II. 1 1 1 


6.00 






11 



RATE 



NAME 



No. SHARES 



AMOUNT 



RATE No. SHARES AMOUNT 



t 



READ: AN ITEM INTO MEMORY 



FROM 
B 





9 8 7 


6 


5 


4 


3 


2 


1 





386 





1 


5 





^ 


> 


-<: 


::;;;;' 


387 


J A M 


E 


S 


SP 


J 


SP 


D 


o 


388 


E SP SP 


SP 


SP 


SP 


SP 


SP 


SP 


SP 


389 


Xo 








9 
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SUPPRESS: (386:94) -> 765:83 and 768:50 (Number of shares in check and stub) 



762 
98765432 1 


763 764 
98765432 1 098765432 1 


765 766 767 
98765432 1098765432 1098765432 10 


768 
987654321 


769 
987654321 


9 


6.00 


mMx:^-^^':- 






150 


:■ ■•'■'Sj '■;"':;' 'S^ 


$ 


liiiis 


6.00 


150 




ill 



RATE 



NAME 



No. SHARES 



AMOUNT 



RATE No. SHARES AMOUNT 



MOVE: (387), 2 WORDS -> 763 (Name) 



762 
98765432 1 


763 764 
98765432 1 098765432 1 


765 766 767 
98765432 1098765432 1098765432 10 


768 
98765432 1 


769 
987654321 


9 


6.00 




JAMES J DOE 


f- 


150 


Isiwii:? 


$iiiii':l 




6.00 


150 


iilis||i|;|| 


11 



RATE 



NAME 



No. SHARES 



AMOUNT 



RATE No. SHARES AMOUNT 



EDIT (Dollar Protection): (389:70) -> 766:50 and 767:87 (Amount on check) 



762 
98765432 1 



763 I 764 

9876543210 9 876543210 



765 
98765432 1 



766 
98765432 10 



767 
9876543210 



768 
98765432 1 



769 
98765432 1 



9 



6.00 



JAMES J DOE 



150 



$* * * 900. 00 



6.00 



150 






RATE 



NAME 



No. SHARES 



AMOUNT 



RATE No. SHARES AMOUNT 



COMBINE: (766:60) and (767:97) -> 769:90 (Amount on stub) 



762 
98765432 1 



763 I 764 
9876543210 9 876543210 



765 I 766 I 767 
9876543210 9 876543210 9 876543210 



768 
98765432 1 



769 
98765432 1 



9 



6.00 



JAMES J DOE 



150 



$***900.00 



6.00 



150 



$* * * 900 .00 



m 



RATE 



NAME 



No. SHARES 



AMOUNT 



RATE No. SHARES AMOUNT 



OUTPUT THE EDITED LINE 
W GO TO A 



SHADED AREAS REPRESENT "SPACE" CHARACTERS PLANTED BY THE INITIAL 
CLEARING OPERATIONS. BLANK AREAS REPRESENT "SPACE" CHARACTERS 
PLANTED BY THE EDITING OPERATIONS. 
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TABLE IV-1; Language Code 





NUMERIC 














NUMERIC BITS 
















ZONE 


VALUE OF 






























BITS 


ZONE BITS 


0000 


0001 


0010 


0011 


0100 


0101 


0110 0111 1000 


1001 


1010 


1011 


1100 


1101 


1110 


1111 


00 


: «''" 





1 


2 


3 


4 


5 


6 7 8 


9 


@ 


^ 


SPACE 


& 


• 


» 


01 


-\i " 


— 


A 


B 


C 


D 


E 


F G H 


1 


D 


A 


m 


n 


9 


P 


10 


",t . 


+ 


J 


K 


1 


M 


N 


9 P Q 


R 


% 


£ 


$ 


( 


) 


/ 


11 




♦ 


# 


S 


T 


U 


V 


W X Y 


Z 


d 


s 


u 


Y 


W 


X 



TABLE IV-2: Modification of first word of Instruction by Index Register 



S-value 



~4 A and AF syllables modified 
2 B and BF syllables modified 
1 C and CF syllables modified 



S-values of syllables 



Sum 



Determines combination 
of syllables modified. 



4 

J L 



2 

J L 



If S = O, no Index Register is used, and R is irrelevant. 



TABLE IV-3; Interchange of syllables in »00 



(0OO) before operation 



■lW. ' .lH'.v.'i-WH-H-:- ' .-!-W- ! - 






J L 



Q 



-I i- 



positive 
negative 



(<iOO) after operation 



Runout MERGE 



! j ! jSWS^^JA ! ft ! :viyA!:% i AyjJJ: 






^•.v.%...*..«....*...*....;*s.......*....!«>....gY..^ 



Q. e , 6 



mmimsmmA 



Q e 6 
—J I 



Cutoff MERGE 






J 

I 1 



ift ! :W'yj^: ' ftV:SK ? :^ ' fe ' '-:-: ' :-^>i-:-'-!-! 



Q ® 6 
J I 



J: May be JA, JB, JC 



MERGE 



MERGE assiames the designation of three memory areas (called 
"pockets")* referred to, respectively, as the A, B, G pockets. Except as 
stated below, there is no necessary relationship among the sizes of the 
three pockets. 

The A and B pockets each contain a "string" of items: that is, a 
collection of items which has previously been sorted according to some key, 

MERGE combines the A and B strings into a single new string, which 
appears in the G pocket. 



B 



Rtmotit MERGE proceeds tmtil either the A pocket or the B pocket has 
been exhausted by copjring the last item into the C pocket. Then all items 
remaining in the other pocket are "ran out" by being copied into the C pocket, 
This type of MERGE assumes, therefore, that the G pocket is equal in length 
to the combined lengths of the A and B pockets. 

Gutoff MERGE TProceeds until: 
A pocket exhausted 
or B pocket exhausted 
or G pocket filled 
and then terminates. The next instruction to be executed is selected fiDm 
the appropriate one of three locations, according to the reason for termina- 
tion, and the MERGE instruction, as recorded in the Memory, indicates the 
point at which it teradnated. 



I^T-M-l 



INSTRUCTION FORMAT: 



9 




7 


6 

L _i 


5 U 

1 


3 


2 


1 
1 1 


Op 


,A. 


B 
1 1 


«c . 




V, 


M 


S 


R 


Xl Xr 


Yl Yr 
1 


lllll 






.AF 

,1 1 


BF 

1 J 


,GF. 



AT 



t:iil;li:;^-:'i-i^-;-i-;:;!:ii^:!-i 



JA 



BT. 



CT, 



Operation: "Cutoff" MERGE (MRGE:C) 
Operation Code: M (V - 0, 1) 
Execution Time: (in micro -minutes) 

22 FIXED 

+ 1 IF Index Register used 

+ 10 per comparison of an A- item with a B-item 

(12 IF 2-word key) 

+ 2 per . word moved into C-pocket 
+ 1 if cf termination 



JB 



JC 



Op: operation code. 

M: auto-monitor level: 0, 1, 2, 3. 

S: designates syllables for modification by index-register OOR. 

R: designates OOR as index-register. 

A, B^ C: bases of addresses of first word, first item. A, B, C pockets. 

AF, BF, CF: bases of addresses of first word, last item. A, B, C pockets. 

AT, BT, CT: word-counts, by which A, B, G are augmented before operation begins. 
During "Cutoff" IffiRGE, AT, BT, CT are automatically augmented, and 
indicate the point at which the MERGE terminated. 

L: item length (number of words). 0<L ^99 . 

X, Y: relative addresses, with respect to the first word of each item, of 
words containing the ma.jor and minor control keys, respectively. 

Xl, Xr: locations of left-most and right-most characters, respectively, of 
Yl, Yr: ma.jor and minor control keys. 

NOTE: if a single control key is used, it is specified by Y, Yl, Yr , 
X, Xl, Xr are then Irrelevant. 

JA, JB, JC: address of next instruction if A, B, C termination condition is 
encountered in "Cutoff" MERGE. 

V: variation designator: 



Cutoff 

MERO: 







one control key 


1 


two control keys 



IV-M-2 



INSTRUCTION FORMAT: 



9 


8 


7 

1 


6 


5 4 

1 


3 


2 


1 
1 1 


Op 


.A . 


B 
1 1 


.G . 




V 


M 


S 


R 


Xl Xr 


Yl Yr 


:":-x":-:i"x!;"v- 


■ 


|i 


,AF. 


,BF, 


•iiiiiii-ikiii^ii-i^iit;^::;::;:: 





AT 


BT CT 
« 1 « > 



Operation: "Ruiiout" MERGE (MRGE:R) 

Operation Code: M (V = 2,3) 
Execution Time! (in micro- minutes) 

19 FIXED 

+ 1 IF INDEX Register used 

+ 1 IF -V 

+ 10 per comparison of an A- item with a B-item 

(12 IF 2-word key) 

+ 3 per item runout into C-pocket 

+ 2 per word moved into C-pocket 

(including items runout) 



;i.i .1.1 I.I I I ' l 1 1 M ■ . 






Op: operation code. 

M: auto-monitor level: 0, 1, 2, 3. 

S: designates syllables for modification by index-register OOR, 

R: designates OOR as index-register. 

A, B, C: bases of addresses of first word, first item. A, B, C pockets. 

AF, W : bases of addresses of first word, last item. A, B pockets. 

AT, BT, CT: word-counts, by which A, B, C are augmented before operation begins. 
During "Runout" MERGE, AT, BT, CT remain unchanged, 

L: item length (number of words). < L - 99 . 

X, Y: relative addresses, with respect to the first word of each item, of 
words .containing the ma.jor and minor control keys, respectively, 

Xl, Xr: locations of left-most and right-most characters, respectively, of 
Yl, Yr: ma.jor and minor control keys. 

NOTE: if a single control key is used, it is specified b5'- Y, Yl, Yr, 
X, Xl, Xr are then irrelevant. 

In "Runout" MERGEE, the next instruction in sequence is alwayis 
executed. 

V: variation designator: 



one control key 



two control keys 



Runout 

MERGE 



IV-M-3 



DESCRIPTION OF: 



MERGE 



NOTES: 

1) The comparison made by MERGE is the same as 
that made by COMPARE ALPHANUMERIC. 
Therefore, if the keys are numeric, all negative num- 
bers (in sequence by increasing magnitude) will sort 
behind all positive keys. MERGE may be made to 
yield any desired sorting sequence, however, by using 
ADD BINARY and COMPLEMENT BINARY 
to transform the sorting keys. 

2) If the keys are positive numbers, they may be 
PACKED, and the operation of MERGE will be 
unchanged. Alphabetic characters may be combined 
in a single key with PACKED digits, by using IN- 
SERT. Therefore, MERGE will operate over a 20- 
character alphabetic field, over a 30-digit PACKED 
numeric field, or over a field containing any propor- 
tional combination of alphabetic characters and 
PACKED digits. 



3) "Assembly of Key" mentioned in the Description, 
takes place as follows: 

The minor control key of the next A^ item is 
transferred to a 20-character-long working register 
(Ra), right- justified. 

If two control keys have been specified, the 
major control key of that item is next transferred to 
Ra, right-justified against the left-most character of 
the minor control key. 

The contents of Ra is then the stored Key of the 
next A item. 

The key of the next B item is assembled and 
stored in the same fashion in Rb. 

4) Note that both the first and third words of the 
MERGE Instruction are modified by the Index 
Register, 



START 

A 



Set Up: A ® AT as Address of next A item 
B ® BT as Address of next B item 




^) Augment address of next C item ® L 



<5- 



J 



<S- 



^ 



Address of next A Item A -*- AT 
Address of next B item B -^ BT 
Address of next C item © C -♦- CT 



6 



6 



Set CT 

to zero 



B empt 

6 



Set BT 

to zero 



\ empty 

6 



Next instruction 
from J A 



Next instruction 
from JB 



Runout 

other 

pocket 



Next instruction 
from JC 



Next Instruction 
in Sequence 



OVERFLOW ALARM: Will not be set by this Instruction. 



IV-M-4 



Runout MERGE 

Suggested patterns of memory space allocation 

for minimum space requirements 





> 



If _the number of items, or the item-length, is large, these Runout MERGES 
can be accomplished vdth a considerable saving in Processor time by using 
Cutoff MERGE: 

~ If the A~Exit is selected, the MERGE is complete, since runout wo\ild only 
copy the remaining items of B on top of themselves. 

- If the B-exit is selected, reset the Instruction to Runout MERCffi, set BT 
equal to BF 6 L Q B (i.e. - B ® BT mil refer to the non-existent B-item 
^ich immediately follows W) , and repeat the MERGE Instruction to accom- 
plish the runout of A. 
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TABLE IV-1: 



Language Code 





NUMERIC 














NUMERIC BITS 














ZONE 


VALUE OF 




























BITS 


ZONE BITS 


0000 


0001 


0010 


0011 


0100 


0101 


0110 0111 1000 1001 


1010 


1011 


1100 


1101 


1110 


nil 


00 


Q 





1 


2 


3 


4 


5 


6 7 8 9 


@ 


^ 


SPACE 


& 


• 


1 


01 


■ 1 ' 


— 


A 


B 


C 


D 


E 


F G H 1 


D 


A 


m 


n 


e 


P 


10 


t 


+ 


J 


K 


L 


M 


N 


e P Q R 


% 


£ 


$ 


( 


) 


/ 


11 


% 


♦ 


# 


S 


T 


U 


V 


W X Y Z 


d 


s 


u 


V 


w 


X 



TABLE IV-2: Modification of first word of Instruction by Index Register 



S-value 
4 
2 
1 



A syllable modified 
N syllable modified 
J syllable modified 



S-values of syllables 



Sum Determines combination 
of syllables modified. 



4 

J L 



2 

J U 



1 
J L 



If S = O, no Index Register is used, and R is irrelevant. 



TABLE IV-3: Interchange of syllables in »00 



(^00) before operation 



» V" i' y m ill II 

-J-., ,.fc. \ r,= 



p 

J l_ 



Q 

J U 



(«00) after operation 



positive 
negative 



- 




p 


Q ® 2 












,.M..\.rm„L 


Q® 2 

1 1 


p 



MOVE 

This Instruction moves any designated ntaaber of 
consecutive ftill words from one memorj area to another. 

OVERFLOW ALARM ; Will not be set under any circumstances . 
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INSTRUCTION FORMAT: 



9 


e 


7 


6 


5 U 3 
t 1 


2 10 

1 1 1 


Op 


.A. 


N 
1 1 


, ,c! 


.-,.■-..■. ■ ■ ■ ■ 


V 


M 


S 


r; 


iiiiiiii 


i^Kri-ivix^i-i-^itiS^ilifi 



Operation: MOVE (M3VE) 
Operation Code : N 



DEFINITIONS: 

Op: operation code. 

M: auto-monitor level: 0, 1, 2, 3. 

S: designates syllables for modification 
by index-register OOR, ' 

R: designates OOR as index-register. 

A: base of address of first word which is 
to be moved. 

N: as modified by (OOR), is an address -type 
number which specifies how many consecutive 
words are to be moved. 

C: base of address in which the first word 
moved is to be stored, 

V: variation designator; 

only the sign of V is relevant . 



- N ^ Z99 



IV-N-2 



DESCRIPTION OF: MOVE 

This is not a partial-word operation. 

The full word [A] is transferred to CQ] . Then the f-oll word 
[A ® 1] is transferred to [C ® I] . The operation proceeds j^til the 
nTamber of words specified by N has been moved^y 

Note that the first word moved is stored in its new location 
before the second word is looked mp, &c. Therefore, if C designates the 
cell following the cell designated by A, then jX] will be copied into 
each of the N following cells. 

If N specifies that zero words shall be moved, the Instruction 
moves zero words — that is, it leaves the contents of the memory im- 
changed. 

OTSRFLQW ALARM t Will not be set by this Instrmction. 
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TABLE IV-1; 



Language Code 



ZONE 
BITS 



NUMERIC 
VALUE OF 
ZONE BITS 



NUMERIC BITS 
0000 0001 0010 0011 0100 0101 Olio 0111 1000 1001 1010 1011 1100 1101 1110 nil 



00 
01 
10 

11 



i 



'- ■--' 



1 

- A 

+ J 

* # S T 



23456789(0)^ space & • ' 
BCDEFGHIDAmnop 
KLMN&PQR%£$ ( ) / 



UVWXYZdsu 



w X 



TABLE IV-2: Modification of first word of Instruction by Index Register 



S-value 
4 
2 
1 



Sum 



A syllable modified 
N syllable modified 
C syllable modified 
Determines combination 
of syllables modified. 



S-values of syllables 



4 

J L 



2 

J L, 



1 
J L 



If S = 0, no Index Register is used, and R is irrelevant. 



TABLE IV-3: Interchange of syllables in «00 



(^00) before operation 



1*H-H-V-H-H-H-'' 



iM:Ki:^::::;:ggEia:::::::afefc:::%i 



J L 



Q 



(000) after operation 



no branch 



branch 



positive 
negative 



trir:^ 


p 

1 1 


Q e , 2 




Ff-:^ 


p 

1.., .,i„ 


Q ® 2 
1 1 
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PACK 

niis Instraction permits the programmer to take advantage of 
the fact that only four binary bits are reqtdred to specify any mimeric 
digit. With n-omeric data, therefore, the storage space ordinarily oc- 
cupied by the zero zone-bits of each digit is, in a sense, "wasted", 
particularly in magnetic tape files. 

PACK takes the thirty 6-bit characters in three consecutive 
memory-cells, transforms them into 4-bit digits by discarding their zone- 
bits, and stores them, fifteen to a word, in two consecutive cells. The 
order in which the thirty characters appeared is not changed in this 
transformation. The Instruction performs this operation on as many con- 
secutive 3-word groups as may be specified. 

If any character with a non-zero zone-bit is encountered, the 
next Instruction to be executed will be selected from a "branch" address. 

Since large portions of most files consist of numeric data, the 
numeric portion of the file may be packed for storage, saving one-third 
of the magnetic tape required to store that part of the file, with a 
proportionate saving in tape travel time during file processing. 

While arithmetic operations cannot be performed on the data 
in its packed 4-bit form, all binary and logical operations can be per- 
formed: 

Extract Combine 

Insert Distribute ("Noimal" variation) 

Add Binary ("Normal" variation) Merge 

Complement Binary Move 

Test Bit Sift 

Compare Alpha-numeric Magnetic Tape Copy and Search 

Compare Equality 

In particular, note that MERGE and SIFT can be performed over 
a 30-digit numeric key. 

OVERFLOW ALAEM s Mill not be set under any circumstances . 
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INSTRUCTION FORMAT: 



9 


S 


7 


6 


5 4 3 
1 1 


2 10 
1 1 


Op 


.A. 


^ _ :. N .. 


,G . 




V 


M 


S 


,R 
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Operation: PACK (PACK) 
Operation Code: 



DEFINITIONS: 

Op: operation code. 

M: auto-monitor level: 



0, 1, 2, 3. 



S: designates syllables for modification 
by index-register OOR. 

R: designates OOR as index-register. 

A: base of address of first word of 
first 3-word group to be packed. 

N: as modified by (OOR), is an address-type 
number which specifies how many consecutive 
3-word groups are to be packed. 

C: base of address in which first word of 

first 2-word packed group is to be stored. 

J: address of next Instruction, if any 

character in the data to be packed contains 
a non-zero zone-bit. 

V; variation designator; 

only the sign of V is relevant. 



f N - Z99 
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DESCRIPTION OF: PACK 

This is not a partial-word operation. 

{X] is transferred to a 30-character-long working register 
(Ra), left- justified. [A @ 1] is transferred to Ra, left- justified 
against the right-most character from [A] . [A 6 2) is transferred to 
Ra, left- justified against the right-most character from [A @ I] , com- 
pleting the 3G-character capacity of Ra. 

At this point, we regard the contents of Ra as a "stream" of 
180 bits, which flows from the left end of Ra, through a "valve", toward 
the left end of a 20-character (120-bit) long working register (Re), 

As the first 2 bits flow from Ra, the valve is closed, and 
those bits are lost. Then the valve is opened to permit the passage of 
the next 4 bitis into Re, Then the valve is closed again to discard the 
next 2 bits, opened for the next 4 bits, and so on, until Ra has been 
emptied . 

The left-most 60-bits of Re then replace [C3 , and the right- 
most 60-bits of Re replace [C I] . Then [A © £] , [A © 4] , [A © ^ are 
packed, and put away into [C © 2J , [G © XI • ^e process is repeated until 
N triplets have been packed. If N specifies zero groups to be packed, the 
Instruction performs no operation, and leaves the contents of the memory 
unchanged. 

It will be seen that each pair of bits discarded in the packing 
process comprises the zone-bits of one of the original characters in Ra, 
and that the numeric bits of those characters a,re "packed tight" into Re. 
The 20 characters into which each 3~word group is packed are "pseudo- 
characters" which have no meaning in themselves, but which arise out of 
the characteristics of the Processor, which in all other operations re- 
gards information as being made up of 6-bit characters. 

If any of the discarded zone-bits was a 1-bit, the next Instruc- 
tion to be executed will be selected from J. However, the full N triplets 
are always packed, 

OVERFLOW ALARM ; Will not be set by this Instruction. 
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ILLUSTRATION OF PACK 



In the following diagram, the 30 characters of the 
3-word group to be packed are numbered from 1 to 30, in order 
to illustrate the arrangement of information before and 
after packing. 



BEFORE PACKING 
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1 

; 8 


1 

, 7 


i 6 


5 


1 

> U 


3 


1 

2 


1 

1 


1 


# 


#2 


#3 


#4 


#5 


#6 


#7 


#8 


#9 


# 
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■ . 


■ 








■ 


' 




#' 


#2 


# 3 


#4 


#5 


# 6 


#7 


# 8 


#9 


#20 


















1 
1 


#2 


#22 


#25 


#24 


#25 


#26 


#27 


#28 


#29 


#30 



AFTER PACKING 
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1 
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7 


« 
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6 


5 


1 


u 


3 


1 

1 


2 


1 


1 
1 
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#2 


#3 


#4 


#5 


#6 


#7 


#8 
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#2#3# 4#5 


1 
1 
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1 
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1 
1 


1 

1 

... , • 


» 1 

1 
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ni 


# 8 


#9 


#20 


#21 


#22 


#23^ 


C4 


#25 
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#27 


#28 


#29 


#30 
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Example - PACK Instruction 



Pack three words - starting at location 214, into two words, 
starting with location 327. 



214 



327 



8 






214 00 0110 00 0000 , 00 0100 01 0001 00 0011 , 00 oiio\ 

1 ,. I — • »'.,.' t — ' 1;: ■' I — '- er r,. , j — • 1 _. i — ' 1 , i "^ 




327 1 0110 0000 0100 0001 0011 0110 \ 



^^'^ l;:0Xi-XQQ6i^ 



■:•:•:•;•;•:•:':•: ^.-irivivi:::::::!:;:;:!::;:;:;::::-^^ 

9 8 7 6 



The next Instruction will be taken frcan the "Branch" address J, 

since a non-zero zone bit appears in character-position 6 of cell 214. 
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TABLE IV-1; 



Language Code 



ZONE 
BITS 


NUMERIC 
VALUE OF 
ZONE BITS 


0000 


0001 


0010 


0011 


0100 


0101 


NUMERIC BITS 
0110 0111 1000 1001 


1010 


1011 


1100 


1101 


1110 


nil 


00 
01 
10 
11 


iHii 




+ 


1 

A 
J 

# 


2 
B 
K 
S 


3 
C 
L 

T 


4 
D 
M 
U 


5 
E 

N 
V 


6 7 8 9 
F G H 1 
9 P Q R 
W X Y Z 


@ 
D 
% 
d 



A 
£ 
s 


SPACE 

m 

$ 

u 


& 

n 

( 

Y 


• 

e 
) 
w 


f 

P 

/ 

X 


nil 


III 


W 


III 


li 


III 



TABLE IV-2: Modification of first word of Instruction by Index Register 



S-value 
4 
2 
1 



A syllable modified 
N syllable modified 
C syllable modified 



S- values of syllables 



Sum Determines combination 

of syllables modified. 



4 2^1 



If S =: O, no Index Register is used, and R is irrelevant. 



TABLE IV-3: Interchange of syllables in «00 



(^00) before operation 



"-T* 



t,. i 4 M I I 



Q 



V 


(000) after operation 


positive 
negative 










L, 


' .. ..♦ *. 


P 

1 1 


Q ® 2 








O (?) 9 


P 




"I.Il.^.mI.m.... 


^.KD ^ 





UNPACK 

This Instrtiction operates "upon information -which has pre- 
vioiasly been PACKED. 

It regards the contents of t-wo consecntive memoiy cells as a 
collection of thirty 4-bit digits, adds a pair of zero zone-bits to 
each of them, and stores the resulting thirty 6-bit characters in three 
consecutive cells. The Instruction performs this operation on as many 
2-word groups as may be specified. 

UNPACK is the converse of PACK, and restores information to 
precisely the same form as it had before it was packed (except, of 
course, that any 1-bits in zone-bit positions in the original inforsia- 
tion will be replaced by 0-bit s) . 

OVERFLOW ALAEM ; Will not be set under any circumstances. 
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INSTRUCTION FORMAT: 



9 




7 


6 


5 4 3 
1 1 


2 10 

1 ) 4 


OP 


,A. 


_^.N. „ 


.c . 




V 


M 


s 


R 
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Operation: UNPACK (UIPK) 
Operation Code: P 



DEFINITIONS: 

pj operation code. 

M: auto-monitor level: 0, 1, 2, 3. 

S: designates syllables for modification 
by index-register GOR, 

R: designates OCR as index-register. 

A: base of address of first word of first 
2-word group to be unpacked. 

N: as modified by (00R)\, is an address -tjrpe 
number which specifies hoxv many consecutive 
2-word groups are to be unpacked. 

C: base of address in which first word of 

first 3--word unpacked group is to be stored. 

V: variation designator; 

only the sign of V is relevant. 



~ nAZ99 



IV-F-2 



DESCRIPTION OF: UNPACK 

This is not a partial-word operation. 

This Instruction regards [A] and [A © lO as consisting of 
thirty 4~bit digits^ packed by a PACK Instruction. It adds a pair of 
0-bit s as zone-bits to each 4-feit digit, reconstitmting it as a standard 
6-bit character, and stores the resulting 30 characters in [C] , [G ® I] , 
and [G © 211, 

Then [A © 2] , [A © £1 are unpacked, and put away into [C © 3] , 
[C © Qy [G © 5] , The process is repeated until N pairs have been un- 
packed. If N specifies zero groups to be unpacked, the Instruction per- 
foims no operation, and leaves the contents of the memory unchanged, 

OVERFLOW ALARM ; Will not be set by this Instruction. 



I?^-3 



327: 



214: 



Example - UNPACK Instruction 



Unpack two words - starting at location 327, into three 
words, starting at location 21A. 



: : ' : ' : : :::'v:':H''=:=:':= 



^^^!^!^!v ! ^!^ ! ^^^^^^!^^ ! ^ ! ■^^^^^^^.^■'^>///!^^^!v!^!^^ ! ^^ ! ^^V ' ^ ' • ' ■ ' • ' ^ ' ^^^^^'■'■^^^ ' ^v ! ^!^^ ! ^^ ! ^ ' ^C• ' f '•'•!•■'•!' 

•:•:■:':•:■•*•.■%•.••■•,•<•',•',•'■'.•'■. . .^:■:^^:^:^:■^:^^^^:■;■:■^!.•■'^■^^■■■^■^■ ■■■•X':\-:-:'X-:ii-:':-:''-%'.'.'.'.':'.-. .■■•Xvl-: 



327: 1 01 1000 00 0100 . 00 0100 . 11 0110 ^ 




214: 1 00 0110 00 0000 00 0100 00 0001 00 0011 00 Olio ^ 



:T^^^^Tt^^'!'i•^^i'l•^^t^^^^^:^^^^^^:^^:':^*'^^^^^^^^■*^:•^:':•^^^^!'^:■>?^^!*!'^ 



e 
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TABLE IV-1; 



Language Code 





NUMERIC 














NUMERIC BITS 












ZONE 


VALUE OF 


























BITS 


ZONE BITS 


0000 


0001 


0010 


0011 


0100 


0101 


0110 0111 1000 1001 


1010 


1011 


1100 1101 


1110 


nil 


00 


m 





1 


2 


3 


4 


5 


6 7 8 9 


® 


^ 


SPACE & 


• 


f 


01 


BH 


— 


A 


B 


C 


D 


E 


F G H 1 


U 


A 


m n 





P 


10 


^g 


+ 


J 


K 


L 


M 


N 


9 P Q R 


% 


£ 


$ ( 


) 


/ 


11 


iiillHiiili 


♦ 


# 


S 


T 


U 


V 


W X Y Z 


d 


s 


U Y 


w 


X 



TABLE IV-2: Modification of first word of Instruction by Index Register 



S-value 
4 
2 
1 



A syllable modified 
B syllable modified 
C syllable modified 



S-values of syllables 



Sum Determines combination 

of syllables modified. 



4 

J. L 



2 

J L. 



1 

J L 



If S =: O, no Index Register is used, and R is irrelevant. 



TABLE IV-3: Interchange of syllables in ^0 



(^00) before operation 






.J. 



(«00) after operation 



positive 
negative 



• 


' ; 


P 

1 1 


Q ® _ 3 


.. 


. ..♦ A 






.... .....j„.. 


Q; ® , 3 


p 




S, ."■tnn,,,*; 



SIFT 

The SIFT Instruction calls for a standard item (the sieve) 
and a list of items j sorted according to some key^ which are to be com- 
pared with the standard (that is, sifted through the sieve). 

Those items in the list whose keys are less than, or equal to, 
the key of the sieve will "pass through the sieve" . The first item 
whose key is greater than the key of the sieve will fail to pass through, 
and will terminate the operation,, 

The Instruction counts the number of items which have passed 
through the sieve, and also counts the total number of words in those 
items o 

The principal uses of SIFT ares 

1) For table lookup. The sieve is a dummy item, set up as 
a structural image of the items in the list, and it contains the key 
whose location within the list is to be determined. 

2) As part of a SIFT-SUMMARIZE operation, to summarize similar 
items in a sorted list. The sieve is the first item in the list itself, 
and SIFT counts the number of items (including the first) which have the 
same key as the first item. SUMMARIZE then refers to this it em- count , to 
s\3mmarize the proper number of items. 

"^^^ word-count is then used to augment an Index Register, and 
the SIFT-SUMMARIZE operation is repeated, causing the operation to resume 
at just the point where it previously stopped. The operation of SIFT- 
SUMMARIZE -COUNT is repeated until the entire list has been smmarized. 



OVERFLOW ALARM ; Will not be set under any circumstances. 
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INSTRUCTION FORMAT: 

9 6 7 6 5 4 3 2 10 



Op 



Operation: SIFT (SIFT) 
Operation Code: Q 



V M 



R 



Xl, Xr 



Yl.YrI;: 



:■:•:•:■:■>: 



11 .AF. I t 1 3? I T 



The sieve must be a structural 
image of the items in the 
list. 



DEFINITIONS: 

Op: operation code. 

M: auto-monitor level: 0, 1, 2, 3. 

S: designates syllables for modification 
by index-register OOR. 

R: designates OOR as index-register, 

A: base of address of first word, first 
item in the list to be sifted. 

B: base of address of first -word of the 
sieve, 

G: base of address in which the counts 
are to be stored. 

AF: address of first word, last item 
in the list to be sifted. 

L: item length (number of words per item) Q ^i L -99 

X , Y : relative addresses, with respect to 

the first word of each item, of words 
containing the ma.jor and minor control 
keys, respectively. 

Xl, Xr: locations of left-most and right-most characters, 
Yl, Yr! respectively, of ma.jor and minor control keys. 

NOTE : X, Xl, Xr are not relevant if only one cdntrol is used. 

V: variation designator: 



9 B 7 6 


5 4 3 2 1 


# Words 


# Words # Items 



V 


Specifies 





one control key 


1 


two control keys 
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DESCRIPTION OF: 

NOTES 



SIFT 



1) The comparison made by this Operation is the same as that made by COM- 
PARE ALPHANUMERIC. The Instruction is, therefore, designed to operate 
upon data which has been sorted by use of MERGE. 

2) Keys may be alphanumeric, PACKED numeric, or a combination, as in 
MERGE. 

3) "Assembly of Key" is performed as in MERGE. 



START 

6 

o 
6 

— ►- 

o 



Clear [C] 



Set up A, as modified by (OOR), 
as address of next item 



Assemble and store 
key of sieve as Key B 



Assemble and store 

key of next item as Key A 



Compare Key A with Key B 

Does this item pass through the sieve? 




no: Key A is greater 



yes: 

Key A is smaller, 

or the keys ore equal 



6 



6 




Augment: 

Word Tally £C:86] © L 
Word Tally [C:53] © L 
Item Tally [C:20]© 1 

Augment: 

Address of next item © L 

Has the last item been sifted? 

(Is address of next item >AF?^ 



yes 



OVERFLOW ALARM: Will not be set by this Instruction. 



Sift 
completed 



Next Instruction 
in Sequence 
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Example - SIFT used for Table Lookup 



SIFT terminates when the first item is found whose control 
characters are greater than those of the sieve. It vdll not terminate on an 
"equal to" condition. This must be considered when using the tallies. 

Assume the storage of the list of items shown below. Find the item 
whose control number is 2067-9. Then store the contents of the 64 -field of 
the 1st word of that item, in 050:40 right- justified. 



273 
274 
275 
276 
277 
276 
279 
2S0 
281 
282 
283 
284 
285 
286 

287 
288 
289 
290 
291 
292 
293 



98765432 10 






it^i ^; iii» | ii i i g ii [ >)ilJiirfi < i M i«ii>iiii«itii^ 




w; i«i ; i«i y « w ^ y * W;ryi' ^ M'H ' H^ ^ ^^^ 






ii«iiiiiiiM2_ 4 7 






^'^•^ *i'r* i * i *i^[i i triffi'iini flfiTMiiiijiii i i ii ii ^ii t ) i t'Fjr^^ 



. ; . ; .U i , t .M>*i 






^«{i jJi 4 ^ i « ;>f i(i i«^h j u'> u y . i i y iy; ii ; ^ 











9 8 7 6 


5 4 3 2 10 


921 


Q 2 7 3 1 4 1|0 7 


922 


10 3^0 9 9m 


923 


iiij 2 9103 0201 



924 
925 



141 
142 
143 







2 7 Ol^ 9|0 5 
0|4{7f6 4f9 0}4 






2 6 7 



SIFT 



Plant the 64-f ield 
of the desired 
item into 050:40 



"sieve" 



NOTE: @09:90 is used as- a "throw-away^' cell 
for the unused half of the DISTRIBUTE 



9 8 7 6 5 4 3 2 1 
007 liiO 1 2 10 l"2T0"0n 
after 



050 
after 



J? J 7,6 5 43 2 1 

mrnmmmo o o 3TI 



Location 007 is used as an Index Register by the DISTRIBUTE Instruc- 
tion, The tallies stored in 007 include the item found. Therefore, it is 
necessary for the DISTRIBUTE Instruction to use as a base address a location one 
item-length before the beginning of the list of the items. 

An example of SIFT used with SUT-MARIZE appears on page IV~R-5. 
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SIFTING LONG TABLES 



In dealing with long tables, considerable time can be saved by- 
sifting the table twice: the first time to learn what part of the table 
holds the desired item, and the second time to locate the exact item. 

This procedure is similar to that used in locating a specific 
folder in a filing cabinet when each drawer bears a label showing the lowest 
account-number filed in that drawer. The clerk first examines these labels 
to learn which drawer to open, and then selects the desired folder from 
within that drawer. 

Suppose that the example on the preceeding page had required a 
table of 104 items. We could use a coarse SIFT (in which the item-length 
is stated as 30) to examine every 10th item in the table, and then a fine SIFT 
which would have to examine no more than 10 items within the proper portion 
of the table: 



816 
817 
818 

819 
820 
821 

822 
823 

824 
825 



98765432 


1 


Q 


2 7 3 


14 10 7 


1 





3 


9 9 


MM 


•;•:•;• 


5 ^ 2 


3 6 


S 


i 



Q 


2 4 3 


1 4 l|f> 9 


1 


4 7 


3 


9 9 mm 


■:•:•:• 


5 8 2 


3 


2 1 




6 


7 


* 9 7 





0|0 


8 3 8 318 31 




1 


2 4 


8 2 5jO 5 





4 7 


^"4'TT[4"Tf 



Coarse SIFT. L = 30 causes every 10th item to 
be examined. In effect, we are sifting a table 
of 11 items . 

Fine SIFT* Since the large group containing the 
desired item has already been tallied, this SIFT 
is referenced 30 words before the actual table. 

MODIFY ADD the result of the fine SIFT (*09) 
to the result of the coarse SIFT (007)» 

Plant the proper field of the desired item. Since 
this item has been tallied again, this Instruction 
is referenced 33 words before the actual table. 



The fact that the last large group contains only 4 items, rather 
than 10, need give no concern, since the AF specified in both SIFTS will 
terminate them properly in all cases. 
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In using a double SIFT, it is important that the sum of: 

the number of groups 
plvs the number of items per group 

a table of 120 items might be 



should be as small as poss 


ible. Thus, 


a • 


divided into: 






3 groups of 40 


3 + 40 » 


43 


or 5 groups of 24 


5 + 24 = 


29 


or 6 groups of 20 


6 + 20 « 


26 


or 8 groups of 15 


8 + 15 = 


23 


or 12 groups of 10 


12 + 10 = 


22 


or 10 groups of 12 


10 + 12 - 


22 


or 15 groups of 8 


15 + 8 = 


23 


and so on. 







Since 12 and 10 comprise the pair of factors with the smallest 
sum, the 120 items should be divided into 12 groups of 10 items, or into 
10 groups of 12 items. 

This sane procedure may be extended to a triple SIFT for extremely- 
long tables. The items should be divided so that the three factors have 
the smallest possible sum. 

On the assumption that lookups are spread evenly throughout the 
table, the minimum table-lengths on which it is worth-while to use 
multiple SIFTS are: 





Double SIFT 


Triple SIFT 


1 control key 


30 items 


900 items 


2 control k^s 


25 items 


400 items 
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TABLE IV-1: Language Code 





NUMERIC 














NUMERIC BITS 
















ZONE 


VALUE OF 






























BITS 


ZONE BITS 


0000 


0001 


0010 


0011 


0100 


0101 


0110 0111 1000 


1001 


1010 


1011 


1100 


1101 


1110 


nil 


00 


. A 1 





1 


2 


3 


4 


5 


6 7 8 


9 


@ 


^ 


SPACE 


& 


• 


9 


01 


^B 


— 


A 


B 


C 


D 


E 


F G H 


1 


D 


A 


m 


n 





P 


10 


^fc 


+ 


J 


K 


L 


M 


N 


e P Q 


R 


% 


£ 


$ 


( 


) 


/ 


11 




* 


# 


S 


T 


U 


V 


W X Y 


Z 


d 


s 


u 


V 


w 


X 



TABLE IV-2: Modification of first word of Instruction by Index Register 



S-value 
4 
2 
1 



A syllable modified 
B syllable modified 
C syllable modified 



S-values of syllables 



Sum Determines combination 
of syllables modified. 



4 

J L 



2 

J L. 



X 1. 



If S = 0, no Index Register is used, and R is irrelevant. 



TABLE IV-3: Interchange of syllables in »00 



(^00) before operation 



wi^fi^feM^i'i'i-i^^ffi^^ 



Q 



V 


(^00) after operation 


no branch 


branch 


positive 
negative 














^^^^M 


p 


Q. ® . 3 






P 


J 

1 I 
















^^^^H 


p 


Q.® 3 
^1 1 




I - * ' »._^ k.s 


Q e, 3 


J 

1 I 

















J: May be JC, J@ 



SUMMARIZE 

This Instruction examines 3 in ttim^, a series of Items stored 
in the Processor Memory^ and forms the arithmetic sxm.^ for all the 
Items^ of the quantity appearing in a specified location within each 
Item,, 

The sunmiary total is stored in the C-putaway field, and also 
in cell @00. 

If the summary total exceeds the capacity of the C-field, the 
next instruction to be executed is selected from a "Branch Address" 
specified in the Instruction^ if the summary total also exceeds the 
10-digit capacity of cell ©00^ the next Instruction to be executed is 
selected from a different ^'Branch Address" specified in the Instruction, 

OVERFLOW ALARM ; Will not be set by this Instruction^ since OTerflow 
automatically causes a branch. 
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INSTRUCTION FORl^iAT: 



9 


8 
1 


7 
1 


6 


5 4 

1 


3 


2 


1 
1 1 


0p 


:^:j.:^::.- 


i'..K.-'' 


.c . 




V 


w 


S 


R 


Al Ar 


■Bl Br 


Cl Cr 


' 




'- ,JG. ■ 


' .J@ . ■ 




.L 



Operation: SUMMARIZE (SUM) 
Operation Code: R 



DEFINITIONS: 

Op: operation code. 
M: auto -monitor level: 



0, 1, 2, 3. 



S: designates syllables for modification 
by index-register OOR. 

R: designates OOR as index-register. 

A: base of address of first quantity to 
be included in the Summary. 

Al, Ar: locations of left-most and right-most 
character-positions, respectively, of 
quantity to be summarized, 

B: base of address containing the number 
of quantities to be summarized. This 
number is an address-type number. 

Bl^ Br: locations of left-most and right-most 
character-positions, respectively, of 
the field which designates the number 
of quantities. 

C: base of address in which sximmary total 
is to be stored, 

Cl, Gr: locations of left-most and right-most 
character-positions, respectively, of 
the C -field. 

L: amount by which XaJ is to be augmented 
to find successive quantities to be 
o included in the summary. (L specifies 
the length of the items . ) 

JC: address of next instruction, if summary 
total exceeds the capacity of CcH . 

J@: address of next instruction, if summary 
total exceeds the capacity of @00:90 . 

V: variation designator; 

only the sign of V is relevant. 



- M_AZ99 



NOTE: Summary total is 
also stored, with 
sign, in ©00^90 
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DESCRIPTION OF: 



SUMMARIZE 



START 



Q Clear a Tally 



NOTES 




Store the number of quantities: 
[B] -> Rb (3 characters) , 
right -justified (note i) 

Clear Re (10 characters) 



Set up A, as modified by (OOR), 
as address of next quantity 



Is the Summary completed? 
Is Tally = (Rb)? 



1) In the transfer of [B] to Rb, the zone-bits of the 
right-most two characters are replaced by 0-bits. 

2) In the transfer of NEXT QUANTITY to Ra, 
zone-bits of all cHaracters are replaced by 0-bits. 

3) The sign of each quantity is considered in per- 
forming each addition to the Summary. 

4 ) At the conclusion of the operation, the sign of the 
Summary Total is inserted as the sign-bit of [C], 
and of (@ 00:90). 



YES 



NO 



6 



Putaway 
(Rc)-^@00:90 

(NOTE 4) 



. Was 
'Overflow Re" 

mark set? 



Would there 

he overflow 

in [C] ? 



Putaway 

(Re)-^[C] 

right- 

justified 

(NOTE 4) 



o 



Next quantity -^^ Ra. 
right-justified (note 2) 



O — ~° — O — ^°— GK 



6 

i 



Add next quantity to the Summary: 
(Re) + (Ra) ->► Re (note 3) 



YES 



YES 



Has (Re) overflowed? 



YES 



NO 



<> 



Set "Overflow Re" mark 



Q Augment: Tally ® 1 



Take next 
instruction 
in sequence 



Take next 

instruction 

from JC 



6 



Augment: 

Address of next quantity © L 



Take next 

instruction 

from J@ 



OVERFLOW ALARM: Will not be set by this Instruction. 
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ExaniDle - SUL3-L4RIZE Instruction 



Summarize the amoiints stored in partial word field 96 of the 
third v/ord of each of the folloivlng 3- word items: 



273 
274 
275 
276 

277 
27S 
279 
2S0 
281 
282 
283 
284 
285 
286 

287 
288 
289 
290 
291 
292 
293 
294 
295 
296 
297 
298 
299 
300 
301 
302 



Q 8 7 6 5 4 3 2 1 



OOP! 



^i,M*t.* t » «• • iVv** 



[«^»ftiljtsfaU^4NtMt*U*)Atl|4w»slt%tt«i*««»*T 



«*t«i*i* > S*rV- » *a*v^f^*T'»*T^ 



^.»wM.«i,*.*»*.*«M»*J*«*tVt*f»«*«*t»j*;^«t*? 




6 Oi 



7 2 Op; 




9 8 7 6 


5 4 3 2 


1 


R 


2 7 5 


4 12 8 16 





OJO 


9 6 8 7 


6 


:x:i:::i 


5 


7 5 m 


3 



Location 412 



3 2 610 9 3 2 1 6 7 



Location 816 before 



9 


8 


7 


6 5 4 3 2 


1 





[0 





B 


64264 


2 


1 



©00 before 



^mm 0040 9 9 5 

Location 8I6 after 



To 4 9 9 5 
@00 after 
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EXAI-TLE - SIFT and SUMI^J^RIZE Instructions 



100 
101 
102 
103 
104 
105 
106 
107 
108 
109 
110 
111 
112 
113 
11/|. 
115 
116 
117 
118 
119 
120 
121 
122 
123 
124 
125 
126 
127 
128 
129 
130 
131 
132 
133 
134 



200 
201 
202 
203 
204 
205 



LIST 



98765432 10 



2 


2 


5 5 9 1 


2 


2 


2 6 10 4 


2 


2 


4 


4 5 


2 


3 2 8 11 


4 5 


2 


10 7 7 8 


4 5 


2 


5 10 6 5 


4 5 


2 


3 7 13 5 


2 18 


1 4 


17 3 2 2 


2 18 


1 4 


4 4 7 2 


2 18 


1 4 


2 4 7 3 


7 7 


2 5 


9 5 7 9 7 


2 


3 8 


12 8 5 


2 


3 8 


2 12 2 5 


4 5 


3 8 


4 10 4 


2 18 


3 8 


5 6 5 


3 5 9 


3 8 


7 12 3 5 


3 5 9 


3 8 


8 10 


3 5 9 


3 8 


5 14 7 5 


3 5 9 


3 8 


3 7 5 14 


4 12 


3 8 


12 4 3 


4 12 


3 8 


56510 


4 12 


3 8 


118 


5 7 2 


3 8 


75115 


5 ,9 


3 8 


05065 


7 7 9 


3 8 


27405 


4 5 


6 1 


01419 


4 5 


6 1 


3 6 8 1 


4 5 


6 1 


33025 


2 18 


6 1 


19655 


3 5 9 


6 1 


4 2 5 8 


4 12 


6 1 


4 9 8 3 5 


5 7 2 


6 1 


2 18 3 


5 9 


6 1 


12235 


5 9 


6 1 


5 7 8 7 6 


2 


6 6 


00399 



2 


oT 


16 3 8 8 4 


1 4 


3 


064515 


2 5 


1 


9 5 7 9 7 


3 8 


1 4 


4 7 4 5 3 9 


6 1 


9 


2 7 5 19 3 


6 6 


1 


3 9 9 



There is in memory a list of 35 one-word itens 
describing sales. They contain the class 
of merchandise, the salesman's nujnber, and 
the amount of the sale . 

9 8 7 6 5 4 3210 
Cell 100 



c c c 


s s 


•i^ ^ $ $ $ 



Summarize the sales by salesman; list the 
number of sales made by each salesman. Then 
accumulate total sales and number of 
salesmen active this day. 



Cell 200 
Cell 300 



PROGRAM 



SS##$$$$$^ 




$$$lllll^## 



A. 



387 
38S 

'38? 
390 
391 

392 
393 
394 

395 
396 

397 
398 

399 

400 

'401 
402 

403 

404 
405 



9876543210 



1 


3 8 8 


3 8 8 2 





9 9l9 9 


9 




Q 


10 


10 0^08 





te;"5""2i 


mm: 


6 5 


Mm 


m 


134 


1 


mM 






R 


10 


(^ 8 2 


K 





052 


4020 


5 




m 


A 3 6 


? 5 om 


1 








H 


10 


8 2 







052 


6 5 10 


9 6 





6 


2 


3 9 8 2 


1 


010 


2 019 9 2 



E 


8 


3 5 


3 8 9 








e 3ii 


362 



R 


2 


002300 





o" 


5 0|2 


9 2 


w. 


7 4 


7 4 m 


1 



2 


2 


405300 





0^ 


209910 



ADD; Clear (002). 



SIFT: Tally the like 
items in 008. 



SUMMARIZES The like 
items . 



COMBINE: Salesman's #, 
and # of sales^ 

MOD ADD: Add 1 to 
(002:20) 

COUNT: Augment (002:93) 
and test (002:86) for end. 

SUMMARIZE: Total sales. 



Store number of 
salesmen active 
this day. 



300 0107432706 
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M AGNE TIC TAPES 



GENERAL 



The following terms are used in this section? 

SOURCE TAPEs Any magnetic tape from which information is 
being read. 

DESTINATION TAPEt Any magnetic tape upon which information 
is being written, 

ITEM: A body of information which it is convenient (in a 
given context) to regard as a unita Thus in one context, a 
list of all the transactions affecting a single account may 
be considered a single item; while in another context, each 
individual transaction in the list may be considered an item, 

FHiE-ITEMs An item in the file; an account. 

RECORDS A body of information, recorded on magnetic tape, and 
bounded by a Beginning -of -Re cord Mark (BRM) and an End -of - 
Record Mark (ERM) <. A record will often contain a single item;' 
however it may, at the programmer's convenience,' contain 
several items; or a single item may be divided into several 
records. 

GULP: All the information read from, or written on, magnetic 
tape with a single Instruction. A gulp may consist of one, 
or many, records. 

CONTROL RECORD MARK (CRM); The character "v" (code 11 llOl), 
recorded in Character-Position 4 of the first word of a record, 

CONTROL RECORD, GRM RECORD s A record containing a CRM. Such 
a record is most often used as an End-of-File sentinel. 

REJECT MARK: The character "w" (code 11 1110 ) recorded in 
Character-position 3 of the first word of a record, 

LEADEBi TRAILER? At each end of a magnetic tape, there is a 
portion of the tape upon which information cannot be recorded, 
which serves to attach the tape to the reel, and -vAiich is 
commonly referred to as the "leader". It is often important, 
however, to refer unambiguously to the leader at one end of 
the tape or the other; in order to avoid expressions such as 
"leading leader" and "trailing leader", the two leaders are 
herein referred to as LEADER and TRAILER, respectively. 
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The functions performed by the KGR 304 Magnetic Tape System ares 

READ HiaMTIC TAPE 

One or many records ■ 

Fixed or:-'¥ariable.''leBgth -.re cords ■•:; 

All or part of each record 

Index forward or backward withomt reading 

MITE MAGIETIC TAPE 
One or many records 
Fixed. or variable length records" 

WRITE^OPI 

Using Source and Destination Tapes sinmltaneomsly 
Off-line Copy 

WRITE-GOPY-READ 

Using Source and Destination Tapes simmltaneously 
On-line Copy 

REWMD 

Any Handler in the System 

Off-line rewind 

Any nismber of Handlers simiiltaneoiisly 

The System has been designed to fiirnish the utmost in reliability 
and convenience in providing for all non-routine circumstances -which may 
arise during Hagne tic. Tape operations o Many of these circumstances, such as 
end of tape, reading error, or writing error, can be programmed for; all such 
circumstances are 'automatically detected and ' identified " by the S3rstem« 
Circumstances which cannot be programmed for^ such as broken tape, or refer- 
ence to a non-^existent Controller or Handler ^ are also detected automatically, 
and cause immediate terralnation of all Processor operations, with identif3ring 
information displayed in the Control Console lights. 

An important feature of the 304 Magnetic Tape System is its ability 
to terminate any operation under a wide variety of automatically detected 
circumstances. Termination may occur whether or not the Instruction, as 
specified by the programmer, has been completely executed. If circumstances 
are such that it is not practicable or advisable to execute a Magnetic Tape 
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Instruction at all, that Instruction is aborted; it is not executed, and an 
alternate Instruction is automatically selected for execution instead. 

In order to provide this facility, every Magnetic Tape Instruction 
designates, in the 20-field of the first word, an address J, which is the 
location of the first word of a 3~word Jump Table . This table contains nine 
addresses, or "exits" from the Tape Instruction; each exit corresponds to 
some "non-normal" circumstance which may arise before, or during, execution 
of the Instruction. Each of these circumstances will be detected automatically 
whenever it arises, whereupon execution of the Instruction will be either 
aborted or tenninated, and the Processor will take its next Instruction from 
the appropriate address in the Jtrnip Table. If no "non-normal" circumstance 
arises, execution of the Instruction terminates "normally", and the Processor 
executes the next Instruction in the normal sequence . 

In most operations, a single Jump Table may be used for all Magnetic 
Tape Instructions. 

The addresses in the Jump Table are numbered Jl through J9, and are 
arranged in the following formats 



Cell J 
Cell J e 1 
Cell J © 2 



9^7 



>J3. 



J6 



5 4 3 2 10 



Ziju 



.Jl. 



J5. 



I , . I "^-^1 



J4. 



m J9 ,J8, 


,J7. 



the detailed significance of eaah exit is shown in the Table which 
appears at the end of this sectiohi Briefly, the §jd.ts correspond to the 
following respective circumst^tlties ^ ffl^iiy of which can c^tise either "branch 



IV-Tapes-3 



\,/^ \ 1-^ ,/; -^ I 


I « 


-3 








"1 ^ 


u 


i 


T/^ A 


r/r,/ /V 






/ f / 


V 




-' 


C0j,i ^'^■'^ 








r 1 " ' 


1/ ^•< 





withomt execution" or "branch after termination^^ as appiropriate: 

Jl - Biisj, or Use Lookout 
. J 2 - Error during Read -f r\ 

■J 3 - Control Eecord Mark 
J4 - Knd of Destination Tape 
J5 - End of Source Tape 
J6 - Error during. Write ~T^fk- ^y'^^'^ii^ lf% f^&t)^P' /€/f:7t r. r -%,^A 
J?'- I^rror during Mon-Write portion of Write-Copy B^x-~\$' -4^\,.'/v^ -^ 

^ or Write-€'©py«-Read. 
J8 - Son-^qual Termination of Write-Copy or /.?.„ o ji^ Pi.u'^iP 

¥rite-Copy-Read „ 
-J9 - Error during Write portion ©f Wrlte-Copy or /;:; jtyg P^... /^-/ 
Write--Q'opy~Read , 

The branch conditions are divided into two groups: 

Branch without execution of the tape operation. 
Branch after termination of the tape operation. 

^tte^^oMitions' which' caxLse;- braA.ch' ^ i^itli6ut : e^efc^ same 

ftm ^1 Magnetic Tape Instructions, and will not be repeated under the in- 
dividual Instruction descriptions. They are: 

- Handler busy rewinding 

- Controller busy copying or repositioning 

- Handler in Use Lockout state 

- One of the following conditions had been encountered 
during a previous off-line COPY on the same 
Controller: 

- Error in copying 

" "Inequality" termination 

- End of Source Tape 

- End of Destination Tape 

If any of these conditions exist, the current Magnetic Tape 
Instruction will not be executed ; instead, the Processor will select its next 
Instruction from the appropriate address stored in the Jump Table named 
by the aborted Instruction. 

Once execution of an Instruction has begun^ a number of circum- 
stances may cause it to terminate ^ and some of those circumstances will 
cause a branch after tersiinati@B» 



The description of each Instruction^ in later pages ^ inclmdes a 
list of all conditions which camse termination of that' Instruction o Some ©f 
the conditions are defined as "normal" ^ and cause the Processor to select the 
next Instruction in the normal sequence o The other conditions are defined as 
"non-normal" and cause the Processor to select its next Instruction from the' 
appropriate address stored in the Jump Table named by the terminated Instruc- 
tion,, 

It will seem strange at first that many circwnstances -which terminate 
execution of an Instruction while it is still incomplete are defined as 
"normal" and do not cause a branch,, However^ in the design of the system, the 
list of terminations which were to be defined as "non-normal" was carefully 
chosen for maximum convenience to the programmero 

HEAD TAPE in parti eular^ may often terminate ** normally" eTen though 
execution of the Instruction is incomplete « Since the design philosophy of 
the sjstem must be understood in order to program it .most effectively ^ some of 
the unusual terminations of WM) TAEE^ which are defined as "normal '\ will be 
discussed in detail. 

It must be understood ^ first ^ that although the READ TAPE Instruction 
says "Read N records'% it maj always terminate before the full I records have 
been read, and this termination is defined as "normal" if at least one record 
has been .read without incident o Therefore ^ the READ TAPE Instruction must be 
interpreted as "Read not more than M records*' <, with the recognition that other 
circumstances will detemine exactly how many records are actually to be read„ 

In reading Magnetic Tape, the prograsimer must allocate an area of 
memory to receive the information being reado In order to operate most 
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efficiently^ aiid minimze tape starts and stops ^ he shoiild arrange to fill 
this area as completely as possible with each EKAD TAPE Instruction. 

If the file being processed consists of fixed-length records, there 
is no difficmltj in deciding how many records shall be specified in the In- 
struction. 

But if the file consists of variable -length records, there is no 
way of anticipating, in advance of each READ TAPE Instruction, how many 
records will fit into the allocated memory space <, 

Therefore the BEAD TAPE Instruction specifies J 

"Read as many records (not exceeding N) as will fit 
into the allocated memory space „ Then terminate, 

and note how many records were read.*^ 

The tally of the ntuber of records read is automatically stored in 
Cell @00, as described later^ and in this case, the termination is defined 
as "normal", if at least one record has been read. With a single Instruction, 
following the HEAD TAEE^ the programmer then plants this tally in a GOUIT 
Instruction, so that the correct number of records will be processed, and 
also in the succeeding WRITE TAPE Instruction, so that the correct number of 
records will be recorded on the updated file tape. 

Even though fixed-length records are being processed, a READ TAFE 
Instruction may be terminated by a reading error, ©r by finding a Control 
Record, before the full N records have been read,, Unless the error record, 
or the Control Record, is the vei^ first record read, this information is of 
no value at this point, since the preceding records read must be processed 
and disposed of before dealing with the error record or Control Record. 
Therefore, if at least one record has been read, before the error record or 
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the Control Record ^ this termination is also defined as "normal '% and the 
tally of records read^ not including the error record or the Control Record, 
is atitomaticallj stored in Cell @00o On the next repetition of the READ TAPE 
Instruction^ the Control Record or (if the error persists) the error record 
will be encomitered again ^ btat this time it will be the first,, and only., 
record reado The Processor will branch after termination of the READ TAPE.^ 
to execute that portion of the program which deals with READ errors^ or with 
Control Records o 

Similarly^ if READ TAPE is terminated by reaching the end of the 
tape^ less than N records will haTe been read, bmt as long as at least one 
record has been read^ the information that end-of-tape has been reached is 

of no Talme until after those records which have been read are processed and 
disposed of. Therefore^ this teimination^ t©©^ is defined as **n©rmaP if at 
least one record has been read^ and the tally of records read is automatically 
stored in Cell @0Qo The aext time the READ TAPE is executed ^ the end of the 
tape will again be encountered ^ and the Instruction will terminate o Bat this 
time, the Processor will not have read *'at least one record*' | no records will 
have been read, and the Processor will branch after termination of the READ 
TAPE, to execute that portion of the program which alternates Handlers so , 
that the next reel of the file may be processed o 

Thus, by defining termination as ^^normal" wheneTer at least one 
record has been read without incident, information about an unusual situation 
is made aTailable at jmst the moment when it can most efficiently and c©n~ 
Teniently be msedo 

It is not necessary to discuss in detail other xinusual terminations 
of Magnetic Tape Instructions which are defined as "normal *% since increasing 
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familiarity mth the system mil bring ©mt the reasomimg behiad the defini- 
ti©iis o 

HEJEGT MAffi g 

A Reject Mark is the character 'V* (e©de 11 lllO) recorded in 
ehara©ter-"p©slti©a 3 ©f the first word ©f a reeordo Smeh a record Td.ll be 
"rejected" by COPI and SEAIGH^ in the sense that the ree®rd will never catise 
the operation t© terminate ^ regardless .of any correspondence between the 
Search Key in the record 3 and the Search Control stored in Memory » A Reject 
Mark has no significance during EE'AD„ 

The Reject Mark is i^ed with files in which items nay be longer than 
the maximmm record-iength (100 words) | smch items will be recorded as two or 

more records — a ^ first" record ^ and as many "trailers" as necessary,, 

In some files ^ each item consists principally ©f account mamber^ 
descriptive information^ several balances j, and a sequential list of transac- 
tions. The main posting operation consists of locating each active accomnt^ 
adjusting the balances ^ and adding the emrrent transactions to the listo In 
smch a case, the balances will be carried in the last record^ the account ntamber 
repeated in each re cord 3 and every record except the last one for each file-item 
will contain the Reject Marko Then the GOPI will stop on the last record for 
..each file-item^, with- only this one record being bromght into the Processor for 
updating o There will be a periodic (perhaps monthly) ©perati©n in which the 
descriptive information and transaction lists will be printed out 3 and each 
file-item redmeed t© a single minimim-length record; this operation will re-- 
quire Reading and Writing every record ^ and the Reject lark will have no signifi- 
cance at that timeo 
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Some other files containing mill ti-re cord items ^ reqmire that a good 
deal of identifying information be stored in each "first" record 5 and irarioms 
operations on the file may call for different Search Kejrs, In order that a 
"trailer'V record (containing information irrelevant to the Search) should 
not 5 by coincidence^ satisfy the Search Condition^ the programmer need only - 
arrange to record the Reject Mark in every record except the first one for 
each file-item ^ and the SEARCH or COPY will stop only on "first" records. 
The presence of the Reject Mark in a "trailer" record nullifies, in effect, 
the preceding ERM-BRM during the SEARCH or COPY^ and therefore each file-item 
is treated by the SEARCH or COPY as thotigh it were a single record of in- 
definite length, 

CONTROL RECORD MARK (CRM) s 

A CRM is the character 'V" (code 11 llGl) recorded in character- 
position 4 of the first word of a record o A Control Record will cause termi- 
nation of any READ,, COPY or ^ARGH^ with appropriate branches as specified in 
the Jiamp Table* A common use of the CRM is to mark the end of a file^ or of 
a section of a file. 

If a record contains both a CRM and a Reject Mark, it will be 
treated as a Reject Record by ^ARCH and COPY^ but as a CRM Record by READ. 



I?»Tapes-9 



CELL @ Q 

As its last act during execTation^ before permitting the Processor 
to proceed to the next Instruction^ eTery Magnetic Tape Instruction automati- 
callj stores certain information about itself in Cell ©OO^ where the program 
may later refer to that inforaiations 

,9. g. 7. 6,5, 4. 3, 2. 1.0, 



Op Co Sh Dh 



K T Q 



Ops Operation code of the Magnetic Tape Instruction which set up (@G0) 

Co, Sh, Dhs Controller, Source-Handler, Destination-Handler numbers actually 
used by the Instruction. 

i.e. -Those named in the Instruction, modified by the 

contents ■ -of an Index Register, 

Kj Differentiates between? Busy or Use Lockout 

Branch without execution 

.■ or after ternination 

T: After HEAD, Tally of number of complete records correctly read. 
After any other Magnetic Tape Instruction, T = . 

Qs Address of the Instruction which set up (@00) . 

Significance of K ; 

After exit to Jl — Leftmost bit-position of K contains? 

1-bit if Handler is in Use Lockout state. 

0«^bit if Controller or Handler is busy. 



After any other exits 



K = if Branch after termination. 
K ]^ Q If Branch without execution. 
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INDEX REGIS1ERS and FILE MANAGEMENT 

As with all other Instructions ^ the first word of every Magnetic 
Tape Instruction can be modified hj the contents of an Index-Register j as 
specified by the S and R digits in the Instruction. For this function^ 
the A-syllable of the Instruction is treated jnst as though it .wers an : 
addres s „ 

In examining the Instruction formats, it will be seen that Co 
(Controller number)^ Sh (Source-Handler number) ^ and Dh (Destination-Handler 
number) are specified in the same character-=positions in every Magnetic Tape 
Instruction^ although Dh is irrelevant to some Instructions^ and Sh is irrele- 
vant to others o 

As a result 5 it becomes quite convenient to designate all Magnetic 
Tape Instructions referring to the Source and Destination Tapes of a single 
file, as relative to the same Index-Register «, Usually, in fact, every 
Magnetic Tape Instruction will be written as though it referred to Controller 
#0, Source-Handler #0, and Destination-flandler #0, with the actual numbers 
being specified entirely in the Index-Register o Therefore, for example, to 
charge Handlers in order to process successive reels of a long file, it is 
sufficient to alternate a single digit in the Index-Register for the Source- 
Handler or for the Destination-Handler^ and then resume the program; each of 
the many Magnetic Tape Instructions used in connection with that file will 
thereby be modified to refer to the alternate Handler. 
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STANDARD TAPE EXECUTIVE PROGRAM 

In writing the programs for any file-processing operation, the 
programmer soon learns that processing the data is only part of his task. 
He must also devote a good deal of attention and effort to a vd.de range 
of problems, which may arise at any point during the processing operation, 
and which are concerned with management of the file (as distinct from 
processing the infonnation in the file). File Management includes the 
sequential processing of successive reels of Magnetic Tape within the 
file, and proper handling of those input and output tapes which are rele- 
vant to the file being processed, f 

' Conditions such as Busy, End of Tape, Error, End of Input, End 
of File, &c, must all be detected whenever they occur, and each condition 
requires that appropriate "housekeeping^ action be taken within the pro- 
gram. These "housekeeping" chores are numerous, and may be classified 
as follows! 

1) Testing, in order to detect that some situation has arisen which re- 
quires "housekeeping" action, 

2) Identifying the condition, and branching to the proper subroutine, to 
take care of precisely that single condition, 

3) Further testing and identifying, since two or more such conditions 
might arise simultaneously, 

4) Writing standard programs to perform those chores which are sub- 
stantially the same for all file operations, ' 

5) Writing a few additional programs for handling those conditions whose 
significance is unique to the immediate operation being performed. 

It has already been pointed out that the electronics of the 
Magnetic Tape System automatically perform the first three functions. 
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Not only is the prograimer thereby relieved of a good deal of time- 
consuming (and therefore expensive) effort, but it becomes impossible 
for him to overlook^ and thus fail to provide for, any circuiastance or 
combination of circumstances whose possibility does not happen to occur 
to him. 

In order that the programmer may also be relieved of the neces- 
sity of providing for function 4, a StaLidard. Tape Executive Program 
(STEP) has been written to perform all routine chores for him. The pro- 
grammer may, in a sense^ look upon STEP as having been "built in" to 
the Processor since^, from his point of view, it occupies no space in the 
Processor Memory, 

The entire STEP program is stored in the "special cells" 
(@00-@99j ^00-^99, D00-D99 J AGO- A.99), leaving the full capacity of the 
Main Memory available for the opes'ating program and for data. No memory 
space is sacrificed to these chores j and no program "overlays" are ever 
necessary in order to perform them. 

Even though the chores which STEP performs for the programmer 
are substantially the same for all file operations^ there are many options 
available to the programmer within STEP . He may wish to intervene with 
some special programming of his own in -the middle of an otherwise routine 
chore, or he may wish to omt certain features of STEP altogether; to do 
any of these^ he need merely specify to STEP which of the available op- 
tions he wishes to exercise. 

The detailed characteristics of STEP have been published in a 
separate manual ^ but they may be summarized briefly here: 
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LABEL-^HECKi 

The first record on each reel of Magnetic Tape -will be recorded 
as a descriptive label ^ containing File Name; Reel Ntoaber within 
the File; Date Recorded; and (if desired) Date on which the in- 
formation becomes obsolete^ when the tape may safely be tised for 
other purposes* 



Before permitting each new Source-Tape reel to be processed, STEP 
verifies that the correct reel^ of the corn 
the correct date, is abotit to be processed. 



Before permitting each new Destination-Tape reel to be processed, 
STEP, verifies (if desired) that the information previously re- 
corded on this tape is obsolete; STEP then records a new label- 
record on this tape, to identify it when it will later be used as 
a Soxirce-Tape , The programmer will specify, separately for each 
file, whether or not this check is desired, and if so, he will 
then specify the length of time for which that file must be pro- 
tected. 



END OF TAPE; 

Rewind the Handler; set Use Lockout if desired; if this is End 
of Source-Tape inform the operator (through the Console Typewriter) 
which reel is now to be mounted on the rewound Handler; if this is 
End of Destination-Tape inform the operator what label is to be 
placed on the reel which is to be removed from the rewound Handler. 

If a multi-reel file is being processed, modify the appropriate 
Index-Register so that the entire program now refers to the alter- 
nate Handler; if End of Tape Is encountered within what should be 
a single-reel file (no alternate Handler specified), STEP will 
tjrpe an appropriate alaim on the Console Typewriter, and halt the 
Processor. 

The programmer has the option of inserting a program of his own, 
before the Handler is rewound. 



ERRORj 



Repeat a specified number of times; resnme if satisfactory; 
otherwise halt. 



DEFECTIVE SPOT ON THE M4GNETIC TAPE SURFACE; 

Automatically skip over all defective spots without attention from 
the programmer or the operator; provide a recoM of the nxamber of 
such spots on each reel. 



BUST: 



Wait; that is, continue to repeat the same Instruction until the 
Controller is no longer busy, and can accept the operation. 
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The programmer has the option , if there is alternative work to 
be time-shared^ of taking this exit out of STEP, and pr©^) 
gramming it himself. 



USE LOCKOUTS 

Halt, ready to resime. The progrannner has the option of pro- 
gramming this condition himself. 



RESCUE POINTS s 

If desired^ STEP -will establish a rescue point each time a 
reel of Magnetic Tape is rewound, and perform a "memory dump" 
on a specified Magnetic Tape. 

BOOTSTRAP FOR RESCUE PROGRAM? 

The Rescue Prograji reads the last "memory dtimp" back into 
Memory, positions every reel of Magnetic Tape at the place 
corresponding to the rescue pointy and resumes execution of 
the program from there „ 

Note that 5 since a rescue point is established just before be- 
ginning each new reel of Magnetic Tape, the latest rescue point 
always corresponds to the precise reels of tape which are 
mounted on the Handlers at anyjiomento Therefore, the rescue 
procedure requires no manual reel- changing, and operates entirely 
under the automatic control of the Rescue Program, 

EXECUTTTE PROGRAMS 

Furnishes a simple, convenient tool for proceeding from one 
program to another^ either automatically under program control, 
or manually under operator control. All tape-exit conditions 
which may arise while reading or recording program-tapes are 
covered o 



ALWAYS READ "N" RECORDS; 

There are occasional circumstances in which the programmer, 
having called for the reading of "N" records from a Magnetic 
Tape, is not content with obtaining fewer than "N" records. He 
then follows the READ with COMPARE NUMERIC; if "N^» is greater 
than (@00?43) he names as a branch address a specified cell 
within STEP , whereuposi ■ a special subroutine will perform 
all necessary "^'bookkeeping" and cause the remaining records to 
be read into the proper area of Memory* 



STANDARD HALT LOCATION'. 

It often happens that some exits cannot (theoretically) occur 
while running certain programs. For example, a program 'Vidiich 
does not use COPY is not expected to encounter conditions which 
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can only arise during a COPT. Such exits might occur as the 
result of malfunction or programming error; and in any case, 
the 304 Magnetic Tape System reqtiires that every branch be 
specified, whether or not the programmer thinks it can occur. 
For such branches, he will specify the Standard Halt Location 
within STEP . From this point, a standard (and simple) 
prescribed procedure will permit the operator to resume the 
processing, invoke the Rescue Program, or call for a complete 
re~run| each of these options may be chosen with or without 
a printout of the contents of Memory, 
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AS A CONSEQUENCE OF THESE FEATURES OF STEP, 
THE ONLY TAPE CONDITIONS! WITH WHICH THE 
PROGRAMMER NEED CONCERN HIMSELF ARE: 



^'Hf CONTROL RECORD MARK J 

^«'- INEQUALITY TERMINATION OF COPYs 

Since the programnier may^ in designing his program, attach 
any significance he chooses to these two circimstances , STEP 
does not provide for these exits. The programmer write his 
own programs for these two circumstances. 



■>or 



BUSYs 



If the programmer wishes to time-share a COPY with processing, 
he will, of coiirsej, program this exit himself. Otherwise he 
will not concern himself with it. 



A complete SUMMARY OF TAFE-.EXIT TABLE appears on the following 
pages, in which all possible Tape-Exit conditions are listed. This table 
is, of course, quite formidable 5 yet it should be appreciated that (aside 
from the comprehensiveness due to a highly sophisticated Magnetic Tape 
processing system)^ the entries in the table are tsrpical of the conditions 
which must always be detected, identified, and programmed for, whenever 
an Electronic Data-Processor uses Magnetic Tape Files. 

This table, however, is of little more than academic interest 
to the programmer, except as an indication of the amount of work which the 
304 Magnetic Tape System, and STEP, have removed from his shoulders. 
He may thus devote his entire time and effort to the processing job itself, 
and write his programs as though all Magnetic Tape equipment remained 
eternally perfect, and as though all Magnetic Tapes were in fact endless. 
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SUMMARY OF 



TAPE-EXIT TABLE 



SHOULD TWO OR MORE CONDITIONS ARISE SIMULTANEOUSLY 
THEY ARE TESTED IN THE FOLLOWING SEQUENCE: 



DETECTED 

BEFORE 

EXECUTION 



DETECTED 

DURING 

EXECUTION 



CONTROLLER BUSY. 

PREVIOUS ERROR. 

PREVIOUS INEQUALITY TERMINATION. 

PREVIOUS WARNING ON DESTINATION TAPE. 

PREVIOUS END OF SOURCE TAPE. 

BUSY HANDLER OR USE-LOCKOUT. 

EXCEED MEMORY ALLOCATION. 

ERROR. 

CRM. 

INEQUALITY TERMINATION OF WRITE-COPY-READ. 

WARNING ON DESTINATION TAPE. 

END OF SOURCE TAPE. 



NORMAL TERMINATION — 
TAKE NEXT INSTRUCTION IN SEQUENCE 


TAPE POSITION 
AFTER TERMINATION. 


TALLY IN $M:43 


READ AT LEAST ONE RECORD; 
TERMINATE BECAUSE: 

N RECORDS READ. 

ChM AFTER FIRST RECORD. 

ERROR AFTER FIRST RECORD. 

EXCEED MEMORY AFTER FIRST RECORD. 

END OF TAPE AFTER FIRST RECORD. 


TO READ THE NEXT RECORD. 

TO READ THE CRM RECORD. 

TO READ THE ERROR RECORD. 

TO READ THE INTERRUPTED RECORD. 

AT THE TRAILER. 


NUMBER OF COMPLETE 
RECORDS READ CORRECTLY. 


INDEX OVER AT LEAST ONE RECORD: 
TERMINATE BECAUSE: 

N RECORDS INDEXED OVER. 

CRM AFTER FIRST RECORD. 

ERROR AFTER FIRST RECORD. 

END OF TAPE AFTER FIRST RECORD. 


TO READ THE NEXT RECORD. 
TO READ THE CRM RECORD. 
TO READ THE ERROR RECORD. 
AT THE TRAILER. 


NUMBER OF RECORDS 
INDEXED OVER. 


INDEX OVER AT LEAST ONE RECORD; 
TERMINATE BECAUSE: 

N RECORDS INDEXED OVER. 

BEGINNING OF TAPE AFTER 
FIRST RECORD. 


TO READ THE Nth RECORD. 
AT THE LEADER. 


NUMBER OF RECORDS 
INDEXED OVER. 


WRITE N RECORDS CORRECTLY. 

IF V = 0,1 NO END-OF-TAPE WARNING 
SIGNAL ENCOUNTERED. 


TO WRITE THE NEXT RECORD. 




WRITE THE RECORD WITHOUT ERROR. 

ANY OTHER CIRCUMSTANCE DURING 
EXECUTION IS TREATED AS OFF-LINE. 

FOR TERMINATION OF OFF-LINE PORTION, 
SEE OPPOSITE PAGE.. 






EQUALITY TERMINATION OF COPY-READ. 

THE TERMINATING RECORD IS IN THE MEMORY. 


SOURCE TAPE 

TO READ THE NEXT RECORD. 

DESTINATION TAPE 

TO WRITE THE TERMINATING RECORD. 





BUSY OR USE-LOCKOUT 
J 1 


ERROR 

DURING READ 

J2 


CONTROL RECORD MARK 
CRM 
J 3 


END-OF-TAPE WARNING SIGNAL 

ON DESTINATION TAPE 

i 4 


END OF SOURCE TAPE 
J S 




BUSY COPYING 

REWINDING 
REPOSITIONING 

(@00:55)< "4-" 

USE-LOCKOUT ON HANDLER 
(@00:55)>"+" 






WARNING ON DESTINATION TAPE DURING PREVIOUS 
WRITE-COPY ON SAME CONTROLLER. 

(@00:5S) ^ 


END OF SOURCE TAPE DURING COPY PORTION 
OF PREVIOUS WRITE-COPY ON SAME 
CONTROLLER. 

(@00:55) :/z 


EXIT 
WITHOUT EXECUTION 


R 

E 
A 

D 




ERROR IN THE FIRST RECORD READ. 
TALLY IN @00:43 IS ZERO. 
(@00:55)r=0 


CRM IN THE FIRST RECORD READ. 
ONLY THAT RECORD IS READ. 
THE TALLY IN @00:43 IS 1. (@00:S5) = 




END OF TAPE WAS ENCOUNTERED BEFORE ANY 
RECORDS WERE READ. 
TALLY IN (S>00:43 IS ZERO. 
(@00:55) == 


EXIT 
AFTER TERMINATION 




TO RE-READ THE ERROR RECORD. 


TO READ THE RECORD FOLLOWING THE CRM RECORD. 




AT THE TRAILER. 


TAPE POSITION AFTER TERMINATION 


BUSY COPYING 

REWINDING 
REPOSITIONING 

(@00:55)< "+" 

USE-LOCKOUT ON HANDLER 
(@00:55)^"4-" 






WARNING ON DESTINATION TAPE DURING PREVIOUS 
WRITE-COPY ON SAME CONTROLLER. 

(@00:55) :^ 


END OF SOURCE TAPE DURING COPY PORTION 
OF PREVIOUS WRITE-COPY ON SAME 
CONTROLLER. 

((S>00:S5) ;£ 


EXIT 
WITHOUT EXECUTION 


1 

N 
D 

E 
X 

F 
O 
R 
W 
A 
R 
D 




ERROR IN THE FIRST RECORD READ. 
TALLY IN @00:43 IS ZERO. 

(@00:55) = 


CRM IN THE FIRST RECORD INDEXED OVER. 
ONLY THAT RECORD IS INDEXED OVER. 
THE TALLY IN @00:43 IS 1. 
(@00:S5) = 




END OF TAPE WAS ENCOUNTERED BEFORE ANY 
RECORDS WERE INDEXED OVER. 

TALLY IN (S)00:43 IS ZERO. 

(@00:55) = 


EXIT 
AFTER TERMINATION 




READ RECORD FgLLSMHiL 


TO READ THE RECORD FOLLOWING THE CRM RECORD. 




AT THE TRAILER. 


TAPE POSITION AFTER TERMINATION 


BUSY COPYING 

REWINDING 
REPOSITIONING 

(@00:55)< "+" 

USE-LOCKOUT ON HANDLER 
(®00:55)>"+" 






WARNING ON DESTINATION TAPE DURING PREVIOUS 
WRITE-COPY ON SAME CONTROLLER. 

((§)00:55) ^ 


END OF SOURCE TAPE DURING COPY PORTION 
OF PREVIOUS WRITE-COPY ON SAME 
CONTROLLER. 

(@00:55) 7^ 


EXIT 
WITHOUT EXECUTION 


1 

N 

D 
E 
X 

B 
A 
C 
K 
W 
A 
R 










LEADER WAS ENCOUNTERED BEFORE ANY RECORDS 
HAVE BEEN INDEXED OVER. 

TALLY IN @00:43 IS ZERO. 

(@00:55) = 


EXIT 
AFTER TERMINATION 










AT THE LEADER 


TAPE POSITION AFTER TERMINATION 


BUSY COPYING 

REWINDING 
REPOSITIONING 

(@00:55)< "+" 

USE-LOCKOUT ON HANDLER 
{@00:55):^"-f" 






WARNING ON DESTINATION TAPE DURING PREVIOUS 
WRITE-COPY ON SAME CONTROLLER. 

(@00:55) ^0 


END OF SOURCE TAPE DURING COPY PORTION 
OF PREVIOUS WRITE-COPY ON SAME 
CONTROLLER. 

(@00:55) ;£ 


EXIT 
WITHOUT EXECUTION 


W 
R 

T 
E 








WARNING SIGNAL DURING WRITE, ONLY IF V = 0,1. 
THE FULL N RECORDS ARE WRITTEN. 
TAPE FROM LAST ERM TO TRAILER IS ERASED. 
(@00:55) = 




EXIT 
AFTER TERMINATION 








AT THE TRAILER. 




TAPE POSITION AFTER TERMINATION 


BUSY COPYING 

REWINDING 
REPOSITIONING 

(@00:55)<"+" 

USE-LOCKOUT ON HANDLER 
(©00:55);^"+" 






WARNING ON DESTINATION TAPE DURING PREVIOUS 
WRITE-COPY ON SAME CONTROLLER. 

(@00:S5) ^ 


END OF SOURCE TAPE DURING COPY PORTION 
OF PREVIOUS WRITE-COPY ON SAME 
CONTROLLER. 

{(8)00:55) r^ 


EXIT 
WITHOUT EXECUTION 


W 
R 
1 , 

T 
E 

C 
O 

P. 
Y 












EXIT 
AFTER TERMINATION 












TAPE POSITION AFTER TERMINATION 


BUSY COPYING 

REWINDING 
REPOSITIONING 

(@00:55) < "+" 

USE-LOCKOUT ON HANDLER 
(@00:55) >"+" 






WARNING ON DESTINATION TAPE DURING PREVIOUS 
WRITE-COPY ON SAME CONTROLLER. 

(@00:55) j!i 


END OF SOURCE TAPE DURING COPY PORTION 
OF PREVIOUS WRITE-COPY ON SAME 
CONTROLLER. 

(@00:55) ^ 


EXIT 
WITHOUT EXECUTION 


W. 
R 
i 

T 
E 

C 
O 

P 
Y 

R 

E 
A 

D 






CRM HAS TERMINATED THE COPY-READ WITH 
CRM RECORD IN THE MEMORY. 
(@00:55)=0 


WARNING ON DESTINATION TAPE DURING WRITE 
OR COPY PORTION. 

FINISH WRITING OR COPYING THE RECORD 
DURING WHICH THE WARNING WAS SENSED. 
ERASE DESTINATION TAPE TO TRAILER. 
(@00:55} = 


END OF SOURCE TAPE HAS TERMINATED 
THE COPY-READ. 

(@00:55) = 


EXIT 
AFTER TERMINATION 






SOURCE TAPE TO READ THE RECORD FOLLOWING 
THE CRM RECORD. 

DESTINATION TAPE TO WRITE THE CRM RECORD. 


SOURCE TAPE TO READ THE NEXT RECORD. 
DESTINATION TAPE AT THE TRAILER. 


SOURCE TAPE AT THE TRAILER. 

DESTINATION TAPE TO WRITE THE NEXT RECORD. 


TAPE POSITION AFTER TERMINATION 





ERROR 

DURINfi WRITE 

J 6 


ERROR 

DURING THE NON-WRITE PORTION OF WRITECOPY OR WRITE-COPYREAD 

J 7 


NON-EaUAL TERMINATION 
J 8 


ERROR 

DURING WRITE PORTION OF WRITE-COfY OR WRITE-COPY-READ 

J 9 


R 

E 
A 
D 


EXrT 
WITHOUT EXECUTION 




ERROR DURING THE COPY PORTION OF A PREVIOUS WRITE-COPY 
ON SAME CONTROLLER. 

{@00:55) 96 


INEQUALITY TERMINATION OF COPY PORTION OF 

PREVIOUS WRITE-COPY ON SAME CONTROLLER. 

(@00:55) ^ 




EXIT 
AFTER TERMINATION 










TAPE POSITION AFTER TERMINATION 










N 

D 
E 
X 

r 
o 

R 
W 
A 
R 

D 


EXIT 
WITHOUT EXECUTION 




ERROR DURING THE COPY PORTION OF A PREVIOUS WRITE-COPY 
ON SAME CONTROLLER. 

(@00:55) ^ 


INEQUALITY TERMINATION OF COPY PORTION OF 

PREVIOUS WRITE-COPY ON SAME CONTROLLER. 

(@00:55) ^ 




EXIT 
AFTER TERMINATION 










TAPE POSITION AFTER TERMINATION 










1 

N 
D 

E 
X 

B 
A 
C 
K 
W 
A 
R 
D 


EXIT 
WITHOUT EXECUTION 




ERROR DURING THE COPY PORTION OF A PREVIOUS WRITE-COPY 
ON SAME CONTROLLER. 

(@00:55) 7^ 


INEQUALITY TERMINATION OF COPY PORTION OF 

PREVIOUS WRITE-COPY ON SAME CONTROLLER. 

(@00:55) y6 




EXIT 
AFTER TERMINATION 










TAPE POSITION AFTER TERMINATION 










W 
R 

1 

T 
E 


EXIT 
WITHOUT EXECUTION 




ERROR DURING THE COPY PORTION OF A PREVIOUS WRITE-COPY 
ON SAME CONTROLLER. 

(@00:55) 7^ 


INEQUALITY TERMINATION OF COPY PORTION OF 

PREVIOUS WRITE-COPY ON SAME CONTROLLER. 

(@00:55) jt 




EXIT 
AFTER TERMINATION 


ERROR IN ANY RECORD DURING SINGLE 
OR MULTIPLE WRITE. 

THE FULL N RECORDS ARE ALWAYS WRITTEN. 

(@00:55) = 








TAPE POSITION AFTER TERMINATION 


TO WRITE THE NEXT RECORD. 








W 
R 

T 
E 

C 

o 
_ p 

Y 


EXIT 
WITHOUT EXECUTION 




ERROR DURING THE COPY PORTION OF A PREVIOUS WRITE-COPY 
ON SAME CONTROLLER. 

(@00:55) jt 


INEQUALITY TERMINATION OF COPY PORTION OF 

PREVIOUS WRITE-COPY ON SAME CONTROLLER. 

(@00:55) ^ 




EXIT 
AFTER TERMINATION 








ERROR DURING WRITE PORTION. (@00:55) = 


TAPE POSITION AFTER TERMINATION 








SAME AS BEFORE EXECUTION. 


W 
R 

" T 

E 

C 
O 

P 
Y 

R 

E 
A 

D 


EXIT 
WITHOUT EXECUTION 




ERROR DURING THE COPY PORTION OF A PREVIOUS WRITE-COPY 
ON SAME CONTROLLER. 

(@00:55) :?i 


INEQUALITY TERMINATION OF COPY PORTION OF 

PREVIOUS WRITE-COPY ON SAME CONTROLLER. 

((8)00:55) ?£ 




EXIT 
AFTER TERMINATION 




ERROR DURING THE COPY OR READ PORTION 
OF WRITE-COPY-READ. 

(@00:55) = 


INEQUALITY TERMINATION OF COPY-READ. 

THE TERMINATING RECORD IS IN THE MEMORY. 

(@00:55) = 


ERROR DURING WRITE PORTION. 

THE FIRST 10 WORDS OF THE RECORD ARE OBLITERATED 
IN THE MEMORY. 

(@00:55) = 


TAPE POSITION AFTER TERMINATION 




SOURCE TAPE TO RE-READ THE ERROR RECORD. 
DESTINATION TAPE TO WRITE THE ERROR RECORD. 


SOURCE TAPE TO READ THE NEXT RECORD. 
DESTINATION TAPE TO WRITE THE TERMINATING RECORD. 


SAME AS BEFORE EXECUTION. 



TERMINATION OF 
OFF-LINE PORTION OF WRITE-COPY 



MARKER 
SET 



TAPE POSITION AFTER TERMINATION 



SOURCE 



DESTINATION 



INEaUALITY TERMINATION. 
EOUALITY TERMINATION. 
CRM. 
ERROR. 



WARNING SIGNAL ON DESTINATION TAPE 
DURING WRITE OR COPY. 

END OF SOURCE TAPE. 



J 8 
NONE 
NONE 
J 7 
J 4 
J 5 



TO READ THE 
TERMINATING RECORD. 



TO READ THE 
CRM RECORD. 

TO RE-READ THE 
ERROR RECORD. 

TO READ THE 
NEXT RECORD. 

AT THE TRAILER. 



TO WRITE THE 
TERMINATING RECORD. 



TO WRITE THE 
CRM RECORD. 

TO WRITE THE 
ERROR RECORD. 

AT THE TRAILER. 



TO WRITE THE 
NEXT RECORD. 



TABLE IV-1: Language Code 





NUMERIC 














NUMERIC BITS 
















ZONE 


VALUE OF 






























BITS 


ZONE BITS 


0000 


0001 


0010 


0011 


0100 


0101 


0110 0111 1000 


1001 


1010 


1011 


1100 


1101 


1110 


nil 


00 


« 





1 


2 


3 


4 


5 


6 7 8 


9 


@ 


^ 


SPACE 


& 


• 


» 


01 


';- 1 '- 


— 


A 


B 


C 


D 


E 


F G H 


1 


D 


A 


m 


n 


9 


P 


10 




+ 


J 


K 


L 


M 


N 


9 P Q 


R 


% 


£ 


$ 


( 


) 


/ 


11 


" 3 -.: 

t-- 


♦ 


# 


S 


T 


U 


Y 


W X Y 


Z 


d 


s 


u 


V 


W 


X 



TABLE IV-2: Modification of first word of Instruction by Index Register 



S-value 



4 CSD syllable modified 
1 J syllable modified 



S-values of syllables 



Sum Determines combination 
of syllables modified. 



4 

J L 



2 

J L 



1 
J L 



If S = 0, no Index Register is used, and R is irrelevant. 



TABLE IV-3: Interchange of syllables in *00 



(^00) before operation 



SffBliyaCT ' i -WvH-H-HW-Hv" 



mmmmmmm 



p 

J L 



Q 



positive 
negative 



(^00) after operation 



no branch 






p 

J L 



Is + 






P 

J L 



Q e 2 
I I 



Q.®.^ 



branch 



...f,i\„„^, I. 



P 

J 1- 



V ' ifV ' VV"^ ' !" ' / ' 1 nil 

':'^f '-^ ; ^ ' Q © 2 



REWIND 
(AND SET USE LOCKOUT ) 



This instruction initiates the Rewind of the tape 
mounted on any Handler on any Controller. As soon as the Rewind 
has been started, control of the actual rewinding is transferred 
to the Handler, and both the Processor and the Controller are 
free to perform any other operations not involving that Handler. 

At the programmer' s option, this Instruction will also 
set a Use Lockout on the rewound Handler. This Lockout will 
prevent access to that Handler by any subsequent Instruction, 
until the Lockout has been released by the operator. 
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INSTRUCTION FORMAT: 
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Operation: REWIND (& SET USE LOCKOUT) 

(WIND) 
Operation Code? S (LGCGK) 



DEFINITIONS: 

Op: operation code. 

M: automonitor level: 0, 1, 2, 3. 

S: designates syllables for modification 
by index-register OOR. 

R: designates OOR as index-register. 

Co: as modified by (OOR), specifies 
controller niiraber. 

Sh: as modified by (OOR) , specifies 
niimber of the source-handler 
used in current processing. 

Dh: as modified by (OOR), specifies 
number of the destination-handler 
used in current processing. 



file-number, used by STEP, See page 
IV-Tapes-12. 

base of address of first word of 
Jump Table. 



V: variation designator: 



Abbreviation 


REWIND 
ONLY 




REWIND 
& LOCKOUT 


Abbreviation 


V specifies 


WIM):S 


--^0 


Rewind Sh. Dh irrelevant 


2 


LefCK:S 


WINDsD 


1 


Rewind Dh. Sh irrelevant 


3 


L€(CK:D 
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DESCRIPTION OF: REWIND (AND SET USE LOCKOUT) 

In order to achieve maximum convenience of tape-management by 
using Index Registers, this Instruction can cause the rewind operation 
to be executed on any Handler, "whether specified in the Source-Tape 
position, or in the Destination-Tape position, of the Instruction. 

As soon as the REWIND signal has been transmitted to the 
specified Handler, both the Processor and the Controller are free from 
the operation, and complete control is transferred to the Handler, 

The Instruction may specify that a Use Lockout shall also be 
placed on the Handler. This lockout will cause a "branch without execu- 
tion" of any subsequent Instruction which refers to that Handler, and 
the Processor will at that time select the next Instruction from one of 
the alternate addresses listed in the Jump Table whose location is 
specified, in the Instruction not executed , by J. 

The only circumstance which can be programmed for, which will 
terminate REWIND^ is reaching the Leader at the beginning of the tape. 

Any circumstance which cannot be programmed for, if detected 
before the REWIND begins, will cause an error-halt, with appropriate 
indication in the Console lights. If such a circumstance arises during 
the REWIND, a "halt marker" will be set in the Controller, as in WRITE- 
COPY. 



Complete details of terminating conditions are shown on page 
IV-S-4. 
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TERMINATING CONDITIONS for REWIND 



CAUSE OF TERMINATION 


RESULT 


Non-existent Controller, or two 
Controllers have the same number 


Processor "Hang-Up" 


Non-existent Handler, or two 
Handlers have the same number 


Controller Error-Halt 


No Tape, or Broken Tape 


Controller Error-Halt 


Broken Tape during Rewind 


Handler Error-Halt 


Beginning of Tape 


Stop Rewind, await next Instruction. 
If specified, set Use Lockout. 



> BEFORE REWIND 



DURING REWIND 
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TABLE IV-1: Language Code 



ZONE 
BITS 


NUMERIC 
VALUE OF 
ZONE BITS 


NUMERIC BITS 
0000 0001 0010 0011 0100 0101 Olio 0111 1000 1001 1010 1011 1100 1101 1110 nil 


00 
01 
10 
11 







O123456789@0 space & • ' 
-ABCDEFGHIDAmnop 
+ J K L M N e P Q R % £ $ ( ) / 
4'#STUVWXYZdsu\rv(rx 








: ... 


a 





TABLE IV-2: Modification of first word of Instruction by Index Register 



S-value 



4 CSD syllable modified 

2 B syllable modified 

1 J syllable modified 



S-values of syllables 



Sum Determines combination 
of syllables modified. 



4 

J L 



2 

J U 



1 
J L 



If S = O, no Index Register is used, and R is irrelevant. 



TABLE IV-3: Interchange of syllables in 0OO 



(^00) before operation 



*.-t^.r± t„^ 



P 

J L 



Q 

J a. 



positive 
negative 



(^00) after operation 



no branch 



t, - i,n,„>...r...-*:...^.., 



P 

J L 



-fc L 



P 

J L 



Q. ® , 2 



Q © 2 



branch 



immmmmm 



P 

J u 



| ^^ ! j^^ ! ^• ! l!^ ! ^ ! ^ ! ^ ! ' ! ^V?:W^■^■^.■■:■:.'.i.;■'■^■ ] .' 



Q e 2 

1 I 



J 

J L 



READ MAGNETIC TAPE 

It is most convenient to describe the READ TAPE Instruction 
as though each of its four major functions were a separate Instruction; 
Read Complete Records Page IV -T -2 

Read Partial Records Page IV-T-4 

Index Forward Without Reading Page IV-T-4 
Index Backward Without Reading Page IV-T-6 

Each of the first three functions will be terminated by a 
Control Record. Such a record was identified when it was recorded, by 
storing a Control Record Mark ("v" — code 11 llOl) in character- 
position k of the first word of the record. 

All functions will automatically detect the physical end of 
the tape, and set up appropriate conditions to permit this circumstance 
to be conveniently handled by the program. 

All functions will operate on records of either uniform or 
varying length. 
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INSTRUCTION FORMAT: 
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Operation: READ COMPLETE, RE CORDS (READ) 
Operation Code: T (V = 0) 



DEFINITIONS: 

Op: operation code, 

M: automonitor level: 0^ 1, 2, 3. 

S: designates syllables for modification 
by index-register OOR. 

R: designates OOR as index- register. 

Co:, as modified by (OOR), specifies 
controller niunber. 

Sh: as modified by (OOR) , specifies 

source-handler number (handler whose 
tape is to be read) . 

B: base of address into which first word 
of first tape-record is to be read. 



Ft 



file-number, used by STEP. See page 
IV-Tapes-12. 

N: number of records to be read. 
00 « N •$ 99 

Z: number of words of processor memory 
allocated for information to be read. 
Z is an address-type nimiber. 

J: base of address of first word of 
Jump Table. 



V: variation designator: 

V = specifies READ Complete Records. 



If N = the Instruction only 

tests for branch before 
execution, and does not 
move tape. (READ:T) 
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DESCRIPTION OF: READ MAGMETXC TAPE ( Read Complete Records ) 



The Instruction specifies that the next N records (whether of 
uniform or varying length) , on the tape mounted on the specified Handler^ 
shall be read into memory. The first word of the first record is to be 
stored in Cell B, and successive words read from the tape are to be stored 
in successive memory cells, B©1, B®2, etc. The operation terminates with 
the tape repositioned to READ again. 

It is important to appreciate the fact that Record-Marks 
(BRM-ERM) exist only on Magnetic Tape, and are not recorded in Memory. 
Thus, once information has been read into Memo ry^ the Magnetic Tape 
records lose their individual identities, as such, and become simply a 
string of items . 

The Processor is free to proceed with the next Instruction as 
soon as the last character of the last record has been read. Stopping and 
repositioning the tape after the READ are supervised entirely by the 
Controller. 

A number of circumstances, all of which can be programmed for, 
will terminate execution of the READ, with fewer than N records actually 
having been read. Some of these circumstances are defined as "normal" 
and will cause the Processor to select the next Instruction in the normal 
sequence; the others will cause the Processor to select the next Instruc- 
tion from one of the Mternate addresses listed in the Jump Table whose 
location is specified by J. 

Whether or not the full N records have been read 5, the Processor 
will always automatically store in @00s43 a tally of the actual number of 
complete records correctly read. 

Any circumstance which cannot be programmed for, will cause an 
error-halt, with appropriate indication in the Console lights. 



Complete details of terminating conditions are shown on page 
IV-T^a. 
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INSTRUCTION FORMAT: 
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Operation: READ PARTIAL RECORDS (READ:P) 



or 



INDEX FORWARD (INDX:F) 
Without Reading 

Operation Code: T (V s 2) 



DEFINITIONS: 

Op: operation code. 

M: automonitor level: 0, 1, 2, 3. 

S: designates syllables for modification 
by index-register OCR. 

R: designates OOR as index- register. 

Co: as modified by (OOR) , specifies 
controller niimber. 

Sh: as modified by (OOR), specifies 

source-handler number (handler whose 
tape is to be read) . 

B: base of address into which first word 
of first tape-record is to be read. 



file-niiraber, used by STEP. See page 
IV-Tapes-12 • 

N: number of records to be read. 
00^ N £. 99 



W: number of words to be read from 
each record (the first W words) 
OOP ^ W ^ 099 

J: base of address of first word 
of Jump Table, 



If N = the Instruction only 

tests for branch before 
execution, and does not 
move tape. 

If W = the Instruction becomes 
' " INDEX FORWARD N Records 
without reading. 
B is irrelevant. 

Minimum record is W © 1 words 



V: variation designator: 

V = 2 ; specifies READ Partial Records 

or INDEX FORWARD without reading. 
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DESCRIPTION OF: READ MAGNETIC TAPE ( Read Partial Records or Index Forward) 



The Instruction specifies that the first W words from each of the 
next N records (whether of uniform or varying length) ^ on the tape mounted 
on a specified Handler, shall be read into memory. The first word of the 
first record is stored in Cell B, and successive words read from the tape 
are stored in successive memory cells, B01^ B®2, etc After the first W 
words of a record have been read, the balance of that record is ignored 
(although all accuracy- checks are made on the complete record) ^ and the 
first word of the following record is stored in the next successive memory 
cell. The operation terminates with the tape repositioned to READ again. 

It is important to appreciate the fact that Record-Marks- (BRM-ERM) 
exist only on Magnetic Tape, and are not recorded in Memory. Thns^ once 
information has been read into Memory, the Magnetic Tape records lose their 
individual identities, as such, and become simply a string of items . 

The time required to read the first W words of each record is 
exactly the same as that required to read each record completely, since the 
Processor is occupied during the entire length of each record. However, if 
all the desired information is in the early portion of each record, then 
reading only a portion of each record will permit more records to be read 
in a single "gulp", and result in a saving of time because fewer tape 
accelerations will be required. Furthermore, even though the complete 
records may be of varying length, the portion of each record containing the 
desired information may be of uniform length, with a resulting increase in 
programming convenience . 

The Processor is free to proceed with the next Instruction as 
soon as the last character of the last record has cleared the Read Head, 
Stopping and repositioning the tape after the READ are supervised entirely 
by the Gontix)ller, 

If the Instruction specifies that the first zero i^rords of each 
record shall be read, the Instruction becomes Index F orward. 

A number of circumstances, all of which can be programmed for, 
will terminate execution of the READ^ with fewer than N records actually 
having been read, or Indexed over. Some of these circumstances are defined 
as "normal" and will cause the Processor to select the next Instruction in 
the normal sequence; the others will cause the Processor to select the 
next Instruction from one of the alternate addresses listed in the Jump 
Table whose location is specified by J. 

Whether or not the full N records have been read, or indexed 
over, the Processor will always automatically store in @0Qs43 a tally of 
the actual number of records read, or indexed over. 

Any circumstance which cannot be programmed for, v/ill cause an 
error-halt, with appropriate indication in the Console lights. 

Complete details of terminating conditions are shown on page 



IV~T-5 



INSTRUCTION FORMAT: 
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Operator? INDEX BACKWARD (INDX:B: 
Without Reading 

Operation Code : T (V s 4) 



DEFINITION 

Op: operation code, 
M: automonitor level: 



0, 1, 2, 3. 



S: designates syllables for modification 
by index-register OOR. 

Rj designates OOR as index-register. 

Co: as modified by (OOR), specifies 
■ controller number, 

Sh: as modified by (OOR), specifies 

source-handler number (handler whose 
tape is to be indexed) . 



T 



file-number, used by STEP. See page 
IV-Tapes-12 . 

N: number of records to be indexed over. 
00 < N ^ 99 

J: base of address of first word of 
Jump Table. 



If N = the Instruction only 

tests for branch before 
execution, and does not 
move tape. 



V: variation designator: 

V = 4 ; specifies INDEX BACKWARD without reading. 
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DESCRIPTION OF: READ MAGNETIC TAPE (index Backward) 



The Instruction specifies that the tape mounted on a specified 
Handler shall be indexed backward N records (whether of uniform or vary- 
ing length), without reading. The operation terminates with the tape 
repositioned to READ. 

If the Handler encounters the Leader at the beginning of the 
tape, before the full N records have been indexed over, the Processor 
will select the next Instruction from one of the alternate addresses 
listed in the Jump Table whose location is specified by J. 

Whether or not the full N records have been indexed over, the 
Processor will always automatically store in @00; 43 a tally of the 
actual number of records indexed over. 

Any circumstance which cannot be programmed for, will cause 
an error-halt with appropriate indication in the Console lights. 



Complete details of terminating conditions are shown on page 
IV-Tr8. 
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TERMINATING CONDITIONS for READ MAGNETIC TAPE 






CAUSE OF TERMINATION 


NEXT 
INSTRUCTION 


AFTER EXECUTION 

TAPE REPOSITIONED 

TO READ 


TALLY IN (@00:43) 


REMARKS 


X 


X 


X 


X 


N complete correct records 


Sequence 


Next Record q 


N 




X 


X 


X 




CRM 


in 1st record 


From J3 


Next Record 


1 


CRM Record is read or 
Indexed over 


X 


X 


X 




after 1 st record 


Sequence 


CRM Record 


# Records 


CRM Record not read 
or Indexed over 


X 








Exceed Memory 
Allocation 


during 1st record 


Processor 
Error-Halt 


Incomplete Record 


O 




X 








after 1st record 


Sequence 


Incomplete Record 


# Records Complete 




X 


X 


X 


X 


End of Tape 

or 

Beginning of Tape 


before 1 st record 


From J5 


Trailer or Leader 


O 




X 


X 


X 


X 


after 1 st record 


Sequence 


Trailer or Leader 


# Records 




X 


X 


X 




Error 


in 1st record 


From J2 


Error Record ^^ 


O 


Error Record in Memory 


X 


X 


X 




after 1 st record 


Sequence 


Error Record 


# Records correct 






X 






Record Less than W©1 Words 


Processor 

Error-Halt 

1 




X 


X 


X 


X 


Failure of Timing-Check 


Controller 
Error-Halt 




X 


X 


X 


X 


Failure BRM-ERM Alternation 


Controller 
Error-Halt 


\\J After Indexing Backward, Tape repositioned 
to read the Nth record. 


X 


X 


X 


X 


Non-existent Controller, or two 
Controllers have the same number 


Processor 
"Hang-Up" 


Q2/ After Indexing Forward, Tape repositioned 
to read the record following the Error Record. 


X 


X 


X 


X 


Non-existent Handler, or two 
Handlers have the same number 


Controller 
Error-Halt 


X 


X 


X 


X 


No Tape, or Broken Tape 


Controller 
Error-Halt 





TABLE IV-1; 



Language Code 





NUMERIC 














NUMERIC BITS 
















ZONE 


VALUE OF 






























BITS 


ZONE BITS 


0000 


0001 


0010 


0011 


0100 


0101 


0110 0111 1000 


1001 


1010 


1011 


1100 


1101 


1110 


nil 


00 







1 


2 
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6 7 8 
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TABLE IV-2: Modification of first word of Instruction by Index Register 



S-value 



4 CSD syllable modified 

2 B syllable modified 

1 J syllable modified 



Sum 



Determines combination 
of syllables modified. 



S-values of syllables 



2 

J L 



1 

J L 



If 8 = 0, no Index Register is used, and R is irrelevant. 



TABLE IV-3: Interchange of syllables in «00 



(«00) before operation 



kJ„...l...u.i I - ] I 



Q 



positive 
negative 



no branch 



».H'M"«VH. iJl 1 H ■ All I 

f r- 



(^00) after operation 



Q e 2 



,v;,.,n 


•i: -j? 


P 

< 1 


Q,® 2 


;. 


fc i-- 



branch 



^- • <- -*- Jl^ 



P 

J u 






Q e 2 



WHITE-COPY 

COPY 

SEARCH 



The WRITE-COPY Instruction requires the assignment of two Handlers 
(Source and Destination) on 'a single Controller. The Instruction per- 
forais three functions? 

FIRSTS l) Write one record^ of a specified lengthy on the Destination Tape,, 
This function may be omitted at the programmer" s optionc, in which 
ease the Instruction becomes COPY, 

THENs 2) Copy the records from the Source Tape onto the Destination Tape„ 
This function may also be omitted at the programmer's option^ in 
which case the Instruction becomes SEARCH, 

ANDs 3) Examine each record on the Source Tape to determine whether it 

satisfies a set of conditions specified in the Instruction o When 
such a record has been found ^ execution of the Instruction termi- 
nates with the tapes properly repositioned to read that record from 
the Source Tape., and to write it on the Destination Tape,, 

Immediately upon the conclusion of function 1 (the writing of one 
record) ^ control of the balance of the operation is transferred from the 
Processor to the Controller as soon as the last character of the record 
has been verified by the Read-Check Head^, and the Processor is free to 
proceed with the program while the Controller independently performs 
functions 2 and 3o During this shared time^ the Processor may perform^ 
without restriction^ any other operation whatever which does not require 
the use of that Controller; this includes all operations on other Con-- 
trollers which may be part of the systemo 

Function 2 operates as a continuous flow of information from the 
Source Tape to the Destination Tapeo Both tapes move at full speed 
throughout the operation^ and since there are no inter-record gaps on 
either tapej no time is lost between records „ 

F\mction 3 may be conducted either as an Equality Search or as a 
Range Search o Equality Search terminates when a record is found whose 
key is identical in every character-position with the Search Control Word 
stored in Memory. Range Search terminates on any record whose key is 
either greater than^ or equal to^ the Search Control Word^ where "greater 
than'* is defined as following according to the alpha-numeric sorting se- 
quence of the Processor code as shown in Table IV" -lo The Search Control 
Word may be split into two portions ^ with independent searches of either 
type specified for each portion. It may also contain "ignore'^ characters 
''u'" (Code 11 1100)5 which are ^'equal to anything". 

A record may contain a Control Record Mark ("v" - Code 11 llOl) in 
character-position 4 of the first word^ and will then always terminate a 
SEARCH or COPY, A record may contain a Reject Mark ("w" - Code 11 lllO) 
in character-position 3 of the first word^ and will then never terminate 
a SEARCH or COPY. If both marks are present in the same record ^ the 
Reject Mark takes precedence. • 
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INSTRUCTION FORMAT: 
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Operation: WRITE -COPY (WC) 

COPY (ce^PY) 

Operation Code: U 



DEFINITIONS: 

Op: operation code. 

M: automonitor level: 0, 1, 2, 3. 

S: designates syllables for modification 
by index-register OOR, 

R: designates OOR as index-register, 

Co,Sh,Dh: as modified by (OOR), 

specify controller number, 
source-handler number and 
destination-handler number. 



If Dh = 5 or 9 , the Instruction 

becomes SEARCH. L is irrelevant. 
]b T| remains as search control 
words . 



B: base of address from v/hich first 
word of tape-record is to be 
written , 

B 1: base of address of search control word. May contain "ignore" character (u). 



L: 



F*:: 



D: 



Y: 

J: 
V: 



length of record to be written. 
015 ~ L ^ 100 

file-number, used by STEP. See 
page IV-Tapes-12. 

divides search control word into 
right-hand (RH) and left-hand (LH) 
portions. D is number of 
characters in RH portion. 

relative address, with respect to 
first word of each record, of 
Search Key. 

base of address of first word of 
Jump Table. 

variation designator: 



Minimum length of written record 

is 15 words. 
If L_=_0, no record is written, and 

the Instruction becomes COPY. 

- D ^7 

No portion of the Search Key may 
lie wholly within the 30-field 
of the first word of a record. 



- Y - 7 



Stop on 
EITHER 


LH 
Search 


RH 
Search 


Stop on 
BOTH 


Marker Set for 
."Inequality" Termination ? 



2 
h 
6 


Equality 
Equality 
Range 
Range 


Equality 
Range 
Equality 
Range 


1 
3 
5 
7 


No 

If Greater found on RH 
If Greater found on LH 
If Greater found on LH 



If D=0: V = 0,1,2,3 causes Equality Search 
V = 4,5,6,7 causes Range Search 



I7-U-2 



DESCRIPTION OF J WRITE-COPY 

Writes A single record, of the specified length, is recorded on the 
tape mounted on the Destination Handler. The record which is to be recorded 
is stored in Cell B and, in successive memory cells B©1, 302^ etc. As soon as 
the WRITE is completed and checked, the Processor is freed from the operation^ 
and control is transferred to the Controller„ If a zero-length record is 
specified, the WRITE is omitted » 

Copy ; Without stopping the Destination Tape, the Source Tape is set 
in motion, and the information from the Source Tape flows through the Controller 
to the Destination Tape, and is written there. If the non-existent Handler 
Number 8 or 9 is specified as the Destination Handler, the WRITE and COPY are 
omitted » 

Search : While the information from the Source Tape is passing 
through the Controller, a specified Search Key in each record is examined by 
the Controller and compared with the Search Control stored in Cell B01. When 
the Search condition is satisfied, the operation terminates with the Source 
Tape repositioned to READ the terminating record, and the Destination Tape 
repositioned to WRITE the terminating record, and the Controller awaits another 
Instruction from the Processor. 

Tvro circumstances, both of which can be programmed for, may arise 
during the WRITE; Error during writing 

End-of-tape warning signal 

In both cases, the operation terminates without initiating the COPY 
and SEARCH. In case of error during the WRITE, the Processor selects the : 
next Instruction from one of the alternate addresses listed in the Jump Table 
whose location is specified by J in the terminated WRITE-COPY Instruction » 
In case of end-of-tape warning during the WRITE, a ^'branchnnarker" is set in 
the Controller, which will cause the next Instruction addressing that Con- 
troller (presumably a READ) to branch without execution ,, as described below. 

Any circumstance arising during the WRITE, which cannot be pro- 
grammed for, will cause the' entire system to halt, with appropriate indication 
on the console lights. 

The COPY and SEARCH^will normally terminate on "equality" (as de- 
fined on the opposite page). However, a number of other circumstances, all 
of which can be programmed for, may also terminate the operation | in some of 
these cases, a "branch-marker" will be set up in the Controller, The next 
time any Instruction refers to that Controller, this marker will be detected, 
and that Instruction will branch "without execution" ; instead of executing 
that Instruction , the Processor will at that time select the next Instruction 
from one of the alternate addresses listed in the Jump TabL© whose location 
is specified, in the aborted Instruction , by J. 

Any circumstance arising during the COPY and SEARCH, which cannot 
be programmed for, will terminate the operation, and set a "halt marker" in 
the Controller. The next time any Instruction refers to that Controller, 
this marker will be detected, and cause an error-halt, with appropriate in- 
dication in the Console lights. 

Complete details of teiminating conditions are shown on page IV-U-4. 



IV-U-3 



TERMINATING CONDITIONS for WRITE-COPY 



< 
■ 

cl 



CAUSE OF TERMINATION 


RESULT 


SOURCE TAPE 

REPOSITIONED 

TO READ 


DESTINATION TAPE 

REPOSITIONED 

TO WRITE 


Error during WRITE 


Next Instruction from J9 


Same as start of Instruction 


Attempt to record a record of less 
than 15, or more than 100, words 


Processor Error-Halt 




All other error conditions fisted for 
WRITE (page IV-W-4) 


Same as for WRITE 


Search Control all "ignores" 


Copy is aborted. 

No branch marker set 


First record on the 
Source-Tape 


Record following Ihe 
written record 


"Equality" termination of COPY ^ 


No branch marker set 


Terminating Record 


Terminating Record 


"Inequality" termination of COPY ^ 


Set marker for branch to J8 


Terminating Record 


Terminating Record 


CRM 


No branch marker set 


CRM Record 


CRM Record 


End-of-tape warning on Destination 
Tape during WRITE 


Set marker for branch to J4 


Same as at start 


Trailer. 

The record is written 


End-of-tape warning on Destination 
Tape during COPY 


Set marker for branch to J4 


Next Record 


Trailer 


End of Source Tape during COPY 


Set marker for branch to J5 


Trailer 


Next Record 


Error during COPY 


Set marker for branch to J7 


Error Record 


Error Record 


Failure of Timing-Check 


Controller Error-Halt 


. 


Failure alternation BRM-ERM 
during COPY 


Controller Error-Halt 




Broken tape during COPY 


Controller Error-Halt 


(?) Defined on page IV-U-2 


Attempt to COPY onto Trailer 


Controller Error-Halt 





~N 
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o 
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TABLE IV-1: Language Code 



ZONE 
BITS 



NUMERIC 
VALUE OF 
ZONE BITS 



NUMERIC BITS 
0000 0001 0010 0011 0100 0101 Olio 0111 1000 1001 1010 1011 1100 1101 1110 nil 



00 
01 
10 

11 





1 
a 



O123456789@0 space & • > 
-ABCDEFGHIDAmnep 
+ JKLMN&PQR %£$()/ 



#STUVWXY 



w X 



TABLE IV-2: Modification of first word of Instruction by Index Register 



S-value 



4 CSD syllable modified 

2 B syllable modified 

1 J syllable modified 



S-values of syllables 



Sum 



Determines combination 
of syllables modified. 



2 
J I- 



1 

J L 



If S = O, no Index Register is used, and R is irrelevant. 



TABLE IV-3: Interchange of syllables in «00 



(^00) before operation 



t...r„i t ' \ 



P 

J L 



Q 



positive 
negative 



no branch 



EH>»"CLW< .Ji.-WV — 



» I ^ "• 'A 



p 

J L 



(0OO) after operation 



Q © 2 



Q © 2 

-ZJ L_. 



branch 



E 



.± y„ 



P 

I I 



L l' ^- '' ^ ■ l"J"W,^ T "J IJ nil 



J 

J L 



WRITE-COPY-READ 

COPY-READ 

SEAR C:;H -READ 



The VJRITE-COPY-READ Instruction require's the assignment of two 
Handlers (Source and Destination) on a single Controller. The Instruc- 
tion performs four functions? 

FIRST: 1. Write one record, of a specified length, on the Destination Tape. 
This function may be omitted at the programmer's option, in which case 
the Instruction becomes COPY-READ. 

THEN: 2. Copy the records from the Source Tape onto the Destination Tape„ 
This function may also be omitted at the programmer" s option, in which 
case the Instruction becomes SEARCH -READ . 

AND: 3. Read each record on the Source Tape into the Processor memory, 
storing the first word of each record in the same cell, so that each 
record is stored "on top" of the previous records, 

AND* 4. Examine each record on the Source Tape to determine whether it 

satisfies a set of conditions specified in the Instruction. When such 
a record has been found, execution of the Instruction terminates, with 
that record stored in the Processor memory, and with the tapes properly 
repositioned to read the following record from the Source Tape, and to 
write the terminating record on the Destination Tape. 

During this entire operation, the Processor itself is controlling 
execution of the Instruction. 

Function 2 operates as a continuous flow of information from the 
Source Tape to the Destination Tape. Both tapes move at full speed 
throughout the operation, and since there are no inter-record gaps on 
either tape, no time is lost between records. 

Function ii may be conducted either as an Equality Search or as a 
Range' Search. Equality Search terminates when a record is found whose 
key is identical in every character-position with the Search Control 
Word stored in Memory. Range Search terminates on any record whose key 
is. either greater than, or equal to, the Search Control Word, where 
"greater than" is defined as following according to the alpha-numeric 
sorting sequence of the Processor Code, as shown in Table IV -1. The 
Search Control Word may be split into two portions, with independent 
searches of either type specified for each portion. It may also contain 
"ignore" characters, "u" (code 11 llOO) which are "equal to anything" „ 

A record may contain a Control Record Mark (^'v" - code 11 llOl) in 
character-position 4 of the first word, and will then always terminate a 
SEARCH or COPY. A record may contain a Reject Mark ("w" - code 11 lllO) 
in character-position 3 of the first word, and will then never terminate 
a SEARCH or COPY. If both marks d,Te present in the same record, the 
Reject Mark takes precedence. 



IV-V-1 



INSTRUCTION FORMAT: 



9 


8 


7 


6 5 




3 


2 10 

1 1 


Op 


Go Sh Dh B 
t 1 II 


J 




' 


M 


s 


R M 


D 


T 


L 
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Operation: WRITE -COPY-READ (¥C:R) 

COPY-READ (Ce)PY:R: 

Operation Code: V 



DEFINITIONS: 

Op: operation code. 

M: automonitor level: 0, 1, 2, 3. 

S: designates syllables for modification 
by index-register OOR. 

Rs designates OOR as index- register, 

Co,Sh,Dh: as modified by (OOR), 

specify controller number, 
source-handler number and 
destination-handler number. 

B: base of address: 

— from which first word of 
tape-record is to be written; 

— into which first 8 words of 
each recoixi copied are to be read; 

— into which complete terminating 
record is to be read, 

B 1; . base of address of search control v;ord. May contain 



^^ Dh = 8 or 9 , the Instruction 
becomes SEARCH-READ. L is 
irrelevant. [B l] remains 
as search control word. 



"ignore" 



characters (u). 



L: 



D: 

Y: 

J: 
V: 



length of record to be written. 
015 - L ^ 100 

file-number, used by STEP. See 
page IV -Tapes -12. 

divides search control word into 
right-hand (RH) and left-hand (LH) 
portions. D is niimber of 
characters in RH portion. 

relative address, with respect to 
first word of each record, of 
Search Key. 

base of address of first word of 
jTjmp Table. 

variation designator: 



Minimum length of written record 

is 15 words. 
If L = . no record is written, and 

the Instruction becomes COPY-READ 







^ D ^ 7 



No portion of the Search Key may 
lie wholly within the 30-f ield 
of the first word of a record. 

- Y ^' 7 



Stop on 

EITHER 


LH 
Search 


RH 
Search 


Stop on 
BOTH 


Marker Set for 
"Inequality" Tennination ? 



2 
4 
6 


Equality 
Equality 
Range 
Range 


Equality 
Range 
Equality 
Range 


1 
3 
5 
7 


No 

If Greater found on RH 
If Greater found on LH 
If Greater found on LH 



If D=0: V = 0,1,2,3 causes Equality Search 
V = 4,5,6,7 causes Range Search 



IV-V-2 



DESCRIPTION OFs WRITE-COPY-READ 



Write: A single record^ of the specified lengthy is recorded 
on the tape moamted on the Destination Handler, The record which is to 
be recorded is stored in Cell B and in successive cells B©1^ 602^ etc„ 
If a zero-length record is specified, the WRITE is omitted. 

Copy : Without stopping the Destination Tape^ the Source Tape 
is set in motion, and the infonnation from the Source Tape flows through 
the Controller to the Destination Tape, and is written there. If the non- 
existent Handler Number 8 or 9 is specified as the Destination Handler, 
the WRITE and COPY are omitted. 

Read : At the same time, each record from the Source Tape is 
transmitted to the Processor and stored in memory. The first word of each 
record is stored in Cell B, with successive xwrds occupying successive 
memory cells. Therefore, the first record to be read replaces in memory 
the record which was written on the Destination Tape, and each succeeding 
record replaces the one before it. When the operation terminates, the last 
record transmitted will remain in memory. 

Search : . During the COPY-READ, a specified Search Key in each 
record is examined by the Controller, and compared with the Search Control 
stored in Cell B91. When the Search condition is satisfied, the operation 
terminates with the Source Tape repositioned to read the record following 
the terminating record, and the Destination Tape repositioned to x-^rrite the 
terminating record, and the Processor goes to the next Instruction, 

The COPY-READ-SEARCH will nomally terminate on "equality" (as 
defined on the opposite page). However, a number of other circumstances j 
all of which can be programmed for, may also terminate the operation; in 
some of these cases, the Processor will select the next Instruction from 
one of the alternate addresses listed in the Jump Table whose location is 
specified by J. 

Any circumstance which cannot be programmed for, will cause an 
error-halt, with appropriate indication in the Console lights. 



Complete details of teiminatlng conditions are shown on page 

IV ^y -4. 

NOTE ; If the Search Control, stored in JMemory, is the word 
Tall "ignore" v' characters) then the Instruction becomes MITEcREAD. The 
record in Memory will be written on the Destination Tape, the COPY will be 
aborted, and the next record from the Source Tape will be read into Memory, 
with no repositioning delay between the WRITE and the READ. It is sometimes 
convenient to process long records one at a time, and in such a case, WRITE- 
READ will defer all repositioning until after the IffiAD is completed, when it 
may conveniently be shared with processing. 
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TERMINATING CONDITIONS for WRITE-COPY-READ 



< 
< 



CAUSE OF TERMINATION 


NEXT 
INSTRUCTION 


SOURCE TAPE 

REPOSITIONED 

TO READ 


DESTINATION TAPE 

REPOSITIONED 

TO WRITE 


CONTENTS OF MEMORY 


"Equality" Termination Q 


Sequence 


Next Record 


Terminating Record 


Terminating Record 


"Inequality" Termination ® 


From J8 


Next Record 


Terminating Record 


Terminating Record 


CRM 


From J 3 


Next Record 


CRM Record 


CRM Record 


Error during WRITE portion 


From J9 


Same as at start of Instruction 


First 8 words of record written have 
been replaced in memory by begin- 
ning of first record copied. 


Error during COPY portion 


From J7 


Error Record 


Error Record 


Error Record 


Error during READ of 
Terminating Record 


From J7 


Terminating Record 


Terminating Record 


Terminating Record 


End of Destination Tape during WRITE 


From J4 


No Movement 


Trailer 


Unchanged 


End of Destination Tape during COPY 


From J4 


Next Record 


Trailer 


First 8 words of last record copied 


End of Source Tape during COPY 


From J5 


Trailer 


Next Record 


First 8 words of last record copied 


Search Control all "ignores". 
COPY is aborted. 


Sequence 


Record following the 
one read into memory 


Record following the 
Written Record 


First record on the Source Tape 


Attempt to record a record of less 
than 1 5, or more than 1 00, words 


Processor 
Error-Halt 




Write Lockout on Destination Handler 


Controller 
Error-Halt 




Failure of Timing-Check 


Controller 
Error-Halt 




Failure BRM-ERM alternation on 
either Handler 


Controller 
Error-Halt 


(j) Defined on Page IV-V-2 


Non-existent Controller, or two 
Controllers have the same number 


Processor 
"Hang-Up" 




Non-existent Handler, or two 
Handlers have the same number 


Controller 
Error-Halt 




No Tape, or Broken Tape 


Controller 
Error-Halt 




Try to Write or Copy on Trailer 


Controller 
Error-Halt 





TABLE IV-1; 



Language Code 





NUMERIC 














NUMERIC BITS 
















ZONE 


VALUE OF 






























BITS 


ZONE BITS 


0000 


0001 


0010 


0011 


0100 


0101 


0110 0111 1000 


1001 


1010 


1011 


1100 


1101 


1110 


nil 


00 


■1 





1 


2 


3 


4 


5 


6 7 8 


9 


@ 


^ 


SPACE 


& 


• 


1 


01 


llllllllll 


— 


A 


B 


C 


D 


E 


F G H 


1 


D 


A 


m 


n 


9 


P 


10 


Pi> 


+ 


J 


K 


L 


M 


N 


e P Q 


R 


% 


£ 


$ 


( 


) 


/ 


11 


3 


♦ 


# 


S 


T 


U 


V 


W X Y 


Z 


d 


s 


u 


Y 


W 


X 



TABLE IV-2: Modification of first word of Instruction by Index Register 



S-value 
4 
2 
1 



Sum 



CSD syllable modified 
B syllable modified 
J syllable modified 
Determines combination 
of syllables modified. 



S-values of syllables 



4 

J L 



2. 

J L 



If 8 = 0, no Index Register is used, and R is irrelevant. 



TABLE IV-3: Interchange of syllables in 0OO 



(^00) before operation 



y VV 



J >■ 



Q 

-I L 



positive 
negative 



(^00) after operation 



no branch 



E H i M"jrw"vw 



.■fe...M..<h... 



Q © 2 
' » 



Q © 2 
_j I 



branch 



:.-M...i ^^ i,.,::„ 



p 

1 I 






Q ® 2 
I I 



J 

J L 



WRITE MAGNETIC TAPE 



The WRITE TAFE Instruction will cause the recording on 
Magnetic Tape of either uniform or varjdng length records. 

If uniform-length records are desired, the record-length is 
specified in the Instruction. 

If varying length records are desired, the length of each 
record must be stored in the 20-field of the first word of each record. 
The Processor will examine this field, and automatically record the cor- 
rect number of words in each record. 

Any record may be designated as a Control Record by storing a 
Control Record Mark ("v" — code 11 llOl) in character-position 4 of 
the first word of the record. 

As a safeguard against running off the end of the tape during 
recording.,, a reflective spot is placed on the back of the tape some 
distance from the end, and is detected automatically as an end-of-tape 
warning during the recording operation. This warning spot is placed 
far enough from the actual end of the tape to permit recording the entire 
contents of the memory between the spot and the end of the tape. There- 
fore, if the warning is detected during execution of any WRITE Instruction, 
there will always remain sufficient usable tape to permit that Instruction 
to be completed. Upon detection of this warning spot, the WRITE Instruc- 
tion is completed, the remaining portion of the tape is erased, and the 
Processor selects its next Instruction from the appropriate one of the 
addresses listed in the Jump Table whose location is specified by J. 
However, the Processor does not wait for the erasing to be performed; it 
proceeds to the next Instruction as soon as the last record has cleared 
the Read-Check Head. 

The reflective spot may be attached by any Service Engineer in 
the field, and places no restriction upon using shorter-length tapes 
whenever desired. 
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INSTRUCTION FORMAT: 
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Op 
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Operation: WRITE MAGlSnETIC TAPE (WT) 
Operation Code: /w" I 



DEFINITIONS: 

Op: operation code. 
M: automonitor level: 



0, 1, 2, 3. 



S: designates syllables for modification 
by index-register COR. 

R: designates OOR as index-register. 

Co: as modified by (OOR), specifies 
controller number. 

Dh: as modified by (OOR)^ specifies 

destination-handler number (handler 
whose tape is to be written) . 

B: base of address from which first word 
of first tape-record is to be written. 



file-number, used by STEP. See page 
IV-Tapes-12. 

N: number of records to be written. 
00 t N - 99 



L: FIXED-LENGTH RECORDS: 
Length of each record. 
010 ^ L ^ 100 

J: base of address of first word 
of Jump Table. 

V: variation designator: 



^f N = the Instruction only 

tests for branch before 
execution, and does not 
move tape. (WT:T) 

VARIABLE-LENOTH RECORDS: 
Length of each record must be stored 
in the 20-field of the first word of 
each record. 

L is irrelevant. 



Abbreviation 


Fixed 

Length 

Records 




Variable 

Length 

Records 


Abbreviation 


After Execution 


¥T:F 





Reposition to write 


1 


¥T:V 


¥TE:F 


2 


Erase tape to trailer 
Ignore end -of -tape 

warning (do not branch) 


3 


¥TE:V 



IV -¥-2 



DESCRIPTION OF: WRITE MAGNETIC TAPE 



The Instruction specifies that N records shall be recorded on 
the tape -which is mounted on the specified Handler. The first word of 
the first record is recorded from Cell B, and successive words. are re- 
corded from successive memory cells ^ B01, B©2j etc. The records may be 
of either uniform or varying length. The operation terminates with the 
tape repositioned to WRITE again. 

It is important to appreciate the fact that Record-Marks 
(BRM-ER14) exist only on Magnetic Tape, and are not recorded in Memory. 
These marks are automatically generated within the Processor, and are 
recorded in the proper places on the tape vdth no attention from the 
programmer. 

The Processor is free to proceed to the next Instruction as 
soon as the last character' of the last record has been verified by the 
Read-Check Head. Stopping, repositioning and (if appropriate) erasing 
the tape are supervised entirely by the Controller, 

Two circumstances, both of which can be programmed for, may 
arise during the WRITE: 

End-of-tape warning signal 

(ignored if V = 2 or 3) 
Error during writing 

In both cases, the full N records will always be recorded, and 
the Processor will select the next Instruction from one of the alternate 
addresses listed in the Jump Table whose location is specified by J. 

Any circumstance which cannot be programmed for, including an 
attempt to write a record of less than 10 words or more than 100 words, 
will cause an error-halt, with appropriate indication in the Console 
lights. 



Complete details of terminating conditions are shown 6n page 
IV -¥^4. 
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TERMINATING CONDITIONS for WRITE MAGNETIC TAPE 



CAUSE OF TERMINATION 


NEXT 
INSTRUCTION 


AFTER EXECUTION 

TAPE REPOSITIONED 

TO WRITE 


REMARKS 


N records written correctly 


Sequence 


Next Record ^ 




End-of-tape Warning 


V = 0, 1 


From J4 


Trailer 


The full N records ore written; 
then tape erased to Trailer 


V-2, 3 


Sequence 


Error 


From J6 


Next Record ^ 


The full N records are written 


Attempt to record a record of less 
than 10, or more than 100, words 


Processor 
Error-Halt 




Write Lockout on Destination Handler 


Controller 
Error-Halt 




Failure of Timir\g-Check 


Controller 
Error-Halt 




Failure BRM-ERM Alternation 


Controller 
Error- Ha It 




Non-existent Controller, or two 
Controllers have the same number 


Processor 
"Hang-Up" 




Non-existent Handler, or two 
Handlers have the same number 


Controller 
Error-Halt 


CJj Repositioned at Trailer 
ifV = 2orV = 3 


No Tape, or Broken Tape 


Controller 
Error-Halt 




Attempt to Write on Trailer 


Controller 
Error-Halt 
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TABLE IV-1: Language Code 





NUMERIC 














NUMERIC BITS 














ZONE 


VALUE OF 




























BITS 


ZONE BITS 


0000 


0001 


0010 


0011 


0100 


0101 


0110 0111 1000 1001 


1010 


1011 


1100 


1101 


1110 


nil 


00 


^^^M 





1 


2 


3 
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5 


6 7 8 9 


@ 
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^^ 
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U 
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s 


u 


Y 


w 
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TABLE IV-2: 



Modification of first word of Instruction by Index Register 



S-value 
4 

1 



Sum 



A syllable modified 

J syllable modified 
Determines combination 
of syllables modified. 



S-values of syllables 



2 
J t. 



1 

-I L 



If S = O, no Index Register is used, and R is irrelevant. 



TABLE IV-3: Interchange of syllables in «00 



($00) before operation 



I* f r* *'... 



J L 



Q 



positive 
negative 



($00) after operation 



no branch 



WM< 




P 


Q_® , 


2 


SSvijB 


» ' '* > 




LJii;:!;!;! 


■;:• '"'i 


P 
1 1 


Q © 

^1 1 


2 




fe- -'<^ ■ 



branch 



T': 


^ 


M 


P 

I 1 


J 

1 1 


F"r 


^ ^ t. 


'M, 
















Q e 

,1.1 


2 


J 

-1- L 


•*•• ■■•* 



PRINT 

The High-Speed Printer may be operated "on-line" (directly 
connected) to the Processor with the PRINT Instruction. The contents of 
tvj'elve consecutive Memoiy Cells are transmitted to a 12-word magnetic core 
register in the Printer. These twelve words comprise a previously-edited 
image of the complete 120-character line which is to be printed. At the same 
time, one additional character (the "slew" control) is also transmitted to 
the Printer. 

"Slewing" is the term used to refer to the \iltra -high-speed move- 
ment of paper between successive lines of printing. Slewing speed is inde- 
pendent of the number of lines slewed, and is the same whether one line, or 
an entire page, is left blank „ Therefore, printing time is- completely de- 
termined by the total number of printed lines, and the total number of blank 
lines, regardless of their respective distribution on the page. 

There are several types of slew control, specified jointly by the 
slew-control character transmitted with the print-line ^ and by a loop of 
punched paper-tape (the slew-control loop) moiuited on the Printer: 

- Slew so as to leave a specified nimiber of blank lines (O to 15) 
between successive lines of printing. 

- Slew to a specified line on the page, identified by one of 15 
possible recognition-codes punched into the slew-control tape. 

- Two of the 15 punched codes are assigned special functions, as 
"skip" code and "stop" code,. They may be used as end-of-page 
and beginning-of~page sentinels. 

Whenever the Printer encounters a "skip" code in the slew-control 
loop, all other slew control is cancelled, and the Printer slews until a 
"stop" code is reached. At the same time, a signal is sent to the Processor, 
with the result that the next PRINT Instruction will branch without execu- 
tion , and an alternative Instruction will be executed instead. 
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INSTRUCTION FORMAT: 
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Operation: PRINT (ri:M^ 
Operation Code: X 



DEFINITIONS: 

Op: operation code, 

M: automonitor level: 0, 1, 2, 3. 

S: selects syllables for modification by 
Index-Register OOR. ' 

R: designates OOR as Index-Register. 

A: base of address of first word of 13-word 
Print Block, set up in Memory: 



A 
9^76^43210 


A © 1 
9876543210 


A © 2 
9876543210 


9 


^^^^M 









A © 11 
9876543210 



A © 12 
9876543210 



Image of the 120-character print line 



U: slew-control. According to Numeric Bits of U: 
U position: Leave to 15 blank lines. 

U negative: Slew till one of 15 recognition-codes is found 
on the slew-control loop. 

Js base of address of Instruction to be executed instead of this PRINT 
Instruction if, after the previous line of print, a "skip" code was 
encountered on the slew-control loop. 

V: variation designator. 

Only the sign of V is relevant. 



BINARY VALUE OF NUMERIC BITS 

1 2 3 4 5 6 7 8 9 10 n 12 13 14 15 
0000 0001 0010 ooii oioo 0101 Olio 0111 1000 1001 1010 1011 1100 1101 1110 nil 
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DESCRIPTION OF: PRINT 



The slew-control character LA: 99] and the twelve words [A © 1] 
through [A 8 12l| are transmitted to the High-Speed Printer and stored, 
respectively, in a 1-character-long Slew-control Register, and in a 120- 
character-long Print-line Register, in the Printer. 

As soon as this transmission has been completed and checked, the 
Processor is released from the Printer which performs all printing, checking, 
and slewing fimctions under its o-wn independent control. The Processor 
immediately proceeds to execute the next Instruction in the Program. 

When the line has been printed and checked, the Printer slews to 
the next printing position on the page. When slewing has been completed, 
the Printer is ready to accept another line of print. If a PRINT Instruction 
is issued while the Printer is still printing or slewing, the Processor will 
wait until slewing has been completed, and then execute the Instruction. 

Slew Control : 

If U is positive (its sign-bit position contains a 0-bit) the 
Printer will leave a number of blank lines (O to 15) equal to the binary 
value of the ntimeric bits of U. 

If U is negative (its sign-bit position contains a 1-bit) the 
Printer will slew until it reaches a punched code in the slew-control loop, 
exactly corresponding to the numeric bits of U. Punches in the tape-loop 
correspond to 1-bits, and non-punches correspond to 0-bits. 

Punched code 1111 (binary 15) is the "skip" code, and may be used 
as end-of-page sentinel. Whenever this code is encoiantered in the slew- 
control loop, all other slew control is cancelled, and "-14" (slew to the 
next "stop" code) is automatically placed in the 1-character-long Slew- 
control Register in the Printer. At the same time, a "branch" marker is set, 
and the next PRINT Instruction will branch without execution . 

Punched code 1110 (binary 14) is the "stop" code, and may be used 
as beginning~of-page sentinel. Whenever this code is encountered in the 
slew-control loop, slewing immediately stops, regardless of the type of 
control which initiated the slewing. 

A "stop" code may be encountered under several circixtnstances: 

a) A "skip" code had previously been encountered; this changed the contents 
of the Printer's Slew-control Register to "-14" (slew to the next "stop" 
code), and set a "branch"marker. Slewing terminates at the "stop" code. 
The next PRINT Instruction will detect the "branch" marker, and will not 
be executed; instead, the Processor will select its next Instruction at 
that time from the address specified by J in the aborted Instraction. 
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b) A "stop" code is not preceded by a "skip" code, and the slew-control 
character is "-14" ("0" or "w"). Slewing will terminate at the "stop" 
code. 

c) A "stop" code is encountered diiring any slewing operation other than 
those described in (a) and (b) . Slewing will terminate at the "stop" 
code, and the Printer will error-halt. 

Punched code 0000 (binary zero) corresponds to unpunched, or blank 
tape, and is not a recognized code on the slew-control loop. If the slew- 
control character is "-0" ("-" or "''^") the Printer will slew, looking for the 
punched code corresponding to binary zero, which does not exist. Slewing 
will continue until a "skip" code or a "stop" code is foimd. This furnishes a 
convenient way to slew through end-of-page to beginning-of -page . 

Overflow Alarm ; 

Of the 64 characters in the Processor language code, 56 are data- 
characters which are pertinent to normal printed output. The eight characters 
mno'puvwx are non-data characters | they are merely convenient names for 
their respective bit-configurations, and are not present on the High-Speed 
Printer. 

If one of these non-data characters should be transmitted for print- 
a.xig, the result depends on the setting of a Switch on the Printer, whose two 
positions are marked PRINT D and HALT . 

In normal operation a non-data character can occur in the output 
only as the result of a programming error. The switch will be set to HALT , 
and the transmittal of a non-data character will cause the Printer to error- 
halt without printing the line. 

However, the eight non-data characters will often be used in pro- 
grams. For Memory printouts, therefore, the Switch will be set to PRINT D . 
Any non-data character wi.ll be, automatically replaced in the Printer by the 
character "□", and the OVERFLOW ALARM id.ll be set in the Processor before it 
is released from the Printer. 

All of the standard Memory-printout programs test for this condi- 
tiono If any non-data characters occurred in a line just printed, the program 
locates them, transforms them into the corresponding capital letters, and 
prints them on an otherwise blank line with each transformed character directly 
below the corresponding "n". 



In order to print "off-line" (from Magnetic Tape, through either the 
Universal Converter or the Printer Converter, to the Printer), a similar Print 
Block is recorded on Magnetic Tape for each line of Print. The contents of 
the 9-character field [A: SO] may then contain identifjdng information to be 
used in connection with the Searching and Selective Printing abilities of the 
Converters, * 



Detains of Printer operation are given in Chapter VI - PERIPHERAL 

EQUIPMENT. 
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TABLE IV-1: Language Code 





NUMERIC 














NUMERIC BITS 
















ZONE 


VALUE OF 






























BITS 


ZONE BITS 


0000 


0001 


0010 


0011 


0100 


0101 


0110 0111 1000 


1001 


1010 


1011 


1100 


1101 


1110 


nil 


00 


Q 
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6 7 8 
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V 
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TABLE IV-2: Modification of first word of Instruction by Index Register 



S-value 
4 
2 
1 



A syllable modified 
N syllable modified 
J syllable modified 



S-values of syllables 



Sum Determines combination 

of syllables modified. 



2 

J L. 



1 
J L 



If S =r O, no Index Register is used, and R is irrelevant. 



TABLE IV-3: Interchange of syllables in «00 



(^00) before operation 



?i:s;w; 


a i r: 


P 

1 1 


,Q, 



(<!00) after operation 



positive 
negative 



- 


'..t \ 


p 


J 

1 ...1 



1 ': T I Q^ e 2 I J 



TYPE /PUNCH 

This Instruction provides facilities for output of information 
in typewritten, or punched paper-tape form, through the Console Typewriter 
itself, the Console Typewriter's paper-tape p\mch, or the High-Speed 
Paper-Tape Punch. 

The Console Typewriter may be used to furnish instructions to 
the operator, and a Log of Operations. 

Replies to interrogations may be furnished through the Console 
Typewriter's paper-tape punch, producing paper tape which can then be 
printed through another typewriter, if it is preferred that this infor- 
mation should not appear on the Log of Operations. 

The High-Speed Paper-Tape Punch may be used for exception- 
reporting, producing a paper-tape which is to be printed through a type- 
writer; it may punch information in telegraphic code, for wire trans- 
mission; or it may, by punching in the appropriate code, provide paper- 
tape for conversion to punched cards. 

Magnetic Tape may also be transcribed to paper tape "off-line" 
throtigh the Universal Converter. For details of Punch operation. 
Converter operation, and punched-tape codes, see Chapter VI - PERIPHERAL 

EQUIPMENT. 
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INSTRUCTION FORMAT: 

9 6 7 6 5 h 3 2 10 



0£ 


1 1 1 t 1 

, A , , N , 


1 ( 




V 


M S R Al Ar ill 


G 

1 1 



(TYPE) 
Operation: TYPE /PUNCH (PPT) 

Operation Code: Y 



DEFINITIONS: 

Op: operation code. 
M: automonitor level: 



0, 1, 2, 3. 



S: selects syllables for modification by 
Index-Register OOR, 

R: designates OOR as Index-Register, 

/ A: base of address of first cell whose 
contents are to be output. 

At J. Ar : left-most and right-most character-positions 
of the partial-word field to be output from 
each successive cell. 

N: as modified by (OOR), specifies the number 
of cells whose contents are to be output. 

G: amount by which the addresses of successive 
output cells are to be augmented, (i.e. 
output the contents of every G^ cell.) 

J: base of address of next Instruction, 
unconditionally . 

V: variation designator: 



000 ^ N^ Z99 

N = means "do nothing" 

OOP £ G ^ Z99 
G = means output [A] , 
N times. 



Abbreviation 


With 

Fixed 

Format 




With 

Programmed 

Format 


Abbreviation 


TYPE: 





Type and Punch on Console Typev/riter 


1 


TYPE: 1 


TYPE; 2 


2 


Punch only on Console Typewriter 


3 


TYPE: 3 


TYRE: 4 


4 


Type only on Console Typewriter 


5 


TYPE: 5 


PPT: F 


6 


Punch on High-Speed Punch 


7 


PPT:- P 



"Tab" after 
contents of 
each cell 



"w" becomes "Tab" 

"x" becomes "Carr Ret" 
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DESGRIPrlON OF: TYPE/PUNCH 

Starting with the character in position Al^ [AH is transmitted, 
character by character, to the output device designated by the chosen varia- 
tion. Then |IA © CO is similarly transmitted; then [A © 2G] is transmitted; 
and so on until the contents of N cells have been transmitted. 

If the code being punched by the output device is a "shifting" code^ 
such as Telegraph Code or the NCR Typewriter Code, the Processor will auto- 
matically insert the required "upshift" and "downshift" characters wherever 
they are required, and transmit them to the output device. 

Fixed Format : After the contents of each cell have been transmitted, 'the 
Processor automatically transmits the character "Tab" to the output device. 

Programnied Format : Whenever the characters "vj-" (code 11 lllO) and "x" (code 
11 llll) are encountered in the information to be transmitted to the output 
device, the Processor substitutes for them the characters "Tab" and "Carriage 
Return", respectively. 

The characters "Tab" and "Carriage Return" do not appear in the 
Language Code of the Processor, but they are. significant characters in many 
punched paper-tape codes, and the ability to punch these characters from the 
Processor furnishes valuable format -control facility. Some paper-tape codes 
use format-control characters other than these, and when punching those codes, 
the Processor transmits format-control characters appropriate to the specific 
code„ (See Chapter VI - PERIPIiERAL EQUIBENT) 

An error-halt v/ill occur if the Processor is called upon to transmit 
a character which does not exist in the code being punched, or if the self- 
checking circuits in the output device detect an error. 
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TABLE IV-1: 



Language Code 





NUMERIC 














NUMERIC BITS 
















ZONE 


VALUE OF 






























BITS 


ZONE BITS 


0000 


0001 


0010 


0011 


0100 


0101 


0110 0111 1000 


1001 


1010 


1011 


1100 


1101 


1110 


nil 


00 
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TABLE IV-2: Modification of first word of Instruction by Index Register 



S-value 
4 

1 



A syllable modified 
J syllable modified 



S-values of syllables 



Sum Determines combination 

of syllables modified. 



4 2 1 



If S = O, no Index Register is used, and R is irrelevant. 



TABLE IV-3: Interchange of syllables in «00 



(^00) before operation 



*- »■ »-■ 



P 

J L 



Q 



V 


(«00) after operation 


positive 
negative 




•' 


J"""'"""""' ': 


"D 


T 
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HALT 

This Instruction stops the Processor, and places it in the 
REST state. 

In the REST state, the Processor will accept information from 
the Console Typewriter. The Instruction provides for automatic disposition 
of any information which the operator may enter; when reaching a point in 
the program at which an operator entry is called for, he need not concern 
himself with the address in which the information is to be stored. 

When the operator presses the START button on the Console, 
automatic execution of the program is resumed. 

The operator may override the automatic provisions for putaway 
of this information, and for resumption of the program, by typing other 
control information, if desired. 
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INSTRUCTION FORI'IAT: 



9 


8 


7 

L __J 
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5 4 3 2 10 


Op 


..A „ 


llllllll , J , 




V 


M 


s 


R 





Operation: HALT (HALT) 
Operation Code? Z (V « O) 



DEFINITIONS: 

Op: operation code. 

M: automonitor level: 0, 1, 2, 3. 

S: selects syllables for modification 
by Index-Register OOR. 

R: designates OOR as Index-Register. 



A: base of address of first putaway if infomiation 
is entered in Memory through the Console 
Typewriter, after the HALT. 

J: base of address of next Instruction, unconditionally . 

V: variation designator: 

V = specifies HALT. 



NOTE: After the HALT, the operator may, by entering appropriate control 
information through the Console Typewriter, over-ride the addresses 
specified by A and J (as modified by OOR), and specify alternative 
addresses. 



TALLIES IN @00 ; 

When Processor operation is resumed: 

(©00:86) contains number of putaways made. 

(©00:33) contains number of characters in last putaway, 

(@00:33) = means 10 characters. 
If no information has been entered, then 

both (©00:86) and (©00:33) will be zero. 
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DESCRIPTION OF: HALT 

The Processor is placed in the REST state, and the REST light on 
the Console is turned on. 

The following conditions are set up within the Processor: (■^^) 

Rp: The address A, as modified by (OOR) , is placed in 
the 3-character-long Putaway-address Register (Rp) . 

^00: The address J, as modified by (OOR), is placed in ^00:20. 

Ri: The length of the Input Register (Ri) is set at 10 
characters, and Ri is cleared. 

Any information entered through the Console Typewriter will, there- 
fore, be stored as a sequence of 10-character putaways to Cells LAH, CA © Q , 
[A © 2], &c, with tallies in ©00:86 and @00:33. 

When the START Button on the Console is pressed, or the "Compute 
Code" key on the Typewriter keyboard is struck, there will be an automatic 
putaway from Ri (unless Ri is empty), and the Processor will resume execution 
of the program, selecting its next Instruction from the address stored in 
(^00:20. 

At any time while the Processor is in the REST state, the operator 
may change (Rp) or ((^00:20) by means of' input-control codes "a" and "c". C"*^") 

NOTE : Punched paper-tape may be read through the Console Typewriter, while 
the Processor is in the REST state. The function of the paper-tape 
in such an operation is to store in "frozen" form the typing v/hich 
caused it to be punched; reading the paper-tape then exactly 
simulates the typing operator. 

Details of Console Typewriter operation are given in Chapter VI - 
PERIPHERAL EQUIPMENT. 



(-") See discussion under READ PAPER TAPE. ("The Input Process", page 
IV>.Z6-4) 
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TABLE IV-1: Language Code 
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TABLE IV-2: Modification of first word of Instruction by Index Register 



S-value 
4 
2 
1 



Sum 



A syllable modified 
N syllable modified 
J syllable modified 
Determines combination 
of syllables modified. 



S-values of syllables 



2 

J L. 



1 
J L 



If S = 0, no Index Register is used, and R is irrelevant. 



TABLE IV-3: Interchange of syllables in «00 



(#00) before operation 



.■■t...r,j >,,r,,,i ■ ■ 



Q 

.J L 



positive 
negative 



(^00) after operation 



no branch 
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1 1 


Qe,2 




: ■■ 


■> 




P 

• 1 


Q® 2 
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t:..,'! 
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branch 



^'.. . 'v*. 



- --^^^ •«• -- 1 



P 

J 1- 



: A. .^ '- Q © 2 



J 

J L 



J: May be Jl, J2, J3 



READ PAPER TAPE 

This Instruction permits the reading of Punched Paper-Tape 
directly into the Processor Memory at extremely high speed. 

Paper tape punched at a vdde variety of data-origination points 
may be read into a single Processing System without the need for code- 
converters, since the High-Speed Paper-Tape Reader will accept tape 
punched in any three codes . 

The ease and accuracy wdth which punched paper-tape can be pre- 
pared (often as a by-product of normal data-recording operations) make it 
an ideal input medium for many applications. The ability to use Input- 
control codes with the data, makes Paper Tape extremely convenient in 
handling unregimented transactions, in which each transaction may not con- 
tain all possible types of information-fields, and in which the length of 
the transactions may vary widely. 

If the volime of input warrants the additional equipment. Paper 
Tape may also be transcribed "off-line" to Magnetic Tape through the 
Universal Converter, as described in Chapter VI - PERIPHERAL EQUIPMENT. 
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iMSTRUCTION FORMAT! 
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Operation: READ PAPER TAPE (RPT) 
Operation Code: Z (V = 6) 



Li 



M S R 



AL^Ar 



ilii; 



>:::;:;v:i-::;: 



DEFINITIONS: 

Op: operation code. 

M: automonitor level: 0, 1, 2, 3. 

S: selects syllables for modification 
by Index-Register OOR. 

R: designates OOR as Index-Register. 

A: base of address of first putaway. 

Alj> Ar: left-most and right-most character-positions 
of each partial-word putaway. 

N: as modified by (OOR) , specifies the 
maximijm nimiber of putaways to be made. 

N=0 means 4000^ regardless of Memory-Size. 

J: base of address of 1-word Jump Table 
for "branch" termination. 

V: variation designator: 

V = 6 specifies RE AD, PAPER TAPE. 



OOP 1 N ^ Z99 
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8 7 6 


5 4 3 2 10 
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, J2, , Jl. 



Normal Termination: 



Branch Terminations : 
Next. Instruction from Jli 

Next Instruction from J2: 

Next Instruction from J3: 



Processor executes next Instruction in the 
normal sequence, if operation terminates 
because of "Compute" code in the paper tape, 

If operation terminates with N putaways. 

If end of paper tape, before N putaways. 

If parity error detected in paper tape. 
The character x (code 11 1111 ) is stored 
instead of the error-character. 



NOTE ; If "Compute" code, end of tape, or error causes the Nth putaway, 
the Jl branch is not taken. 

T ALLIES IN @00 ; 

After any termination: (@00:S6) contains number of putavrays made. 

(@00:33) contains number of characters in last putaway 
(@00:33) = means 10 characters. 

If no information has been read, then 

both (@00:86) and (©00:33) will be zero. 
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DESCRIPTION OF: READ PAPER TAPE 

This Instruction starts the High-Speed Paper-Tape Reader, and 
controls the input process while the tape is being read. 

The following conditions are set up within the Processor: (*) 

Rp: The address A, as modified by (OOR), is placed in the 
3-character-long Putaway-address Register (Rp). 

(j^OO: The address of the next Instruction in the normal 

sequence, remains in (^00:20. Terminating conditions 
of the operation may cause this stored address to be 
replaced by one of the addresses Jl, J2, J3. 

Ri: The length of the Input Register (Ri) is set to the 
length of the AlAr field, and Ri is cleared. 

Information received from the Paper-Tape Reader will, therefore, 
be stored in the AlAr field of each of the Cells LA.'}, EA © X] , [A © 21 , &c, 
with tallies in @00tS6 and @00:33. 

The control-codes "a" and "c" punched into the paper-tape will 
cause the contents of Rp and of (^00 J 20 to be changed. However, (^00:20) 
will still be replaced by the originally-specified Jl, J2 or J3 if the termi- 
nating conditions cause a branch. 

If the Reader* s self -checking circuits detect a reading error, a 
transmission error, or an illegal configuration punched into the tape, it 
will error-halt. 



Paper Tape may be transcribed to Magnetic Tape "off-line" through 
the Universal Converter. For details of Paper-Tape Reader operation. Con- 
verter operation, and paper-tape codes, see Chapter VI ~ PERIPHERAL EQUIPMISNT 



(^0 See discussion of THE INPUT PROCESS, on succeeding pages 
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THE INPUT PROCESS 



The follomng discussion of Paper-Tape input applies equally to 
input of information through the Console Typewriter while the Processor is in 
the REST state, and should be read in connection with the description of HALT. 

Whenever the Processor is receiving data from the Paper-Tape Reader, 
or from the Console Typewriter, the operation is controlled by two working 
registers-: 

The Putaway-address Register (Rp) is 3 characters long, and holds the 
address of the next Memory Cell scheduled to receive information. Immediately 
after each "put away" is made, the contents of Rp are automatically augmented hj 
1 (using MODIFY ADD)^ so that successive putaways are made to consecutively- 
numbered Cells. 

'^^® ^^P^t Register (Ri) varies from 1 to 10 characters in length. 
Before input begins, the length of Ri is automatically set as specified by the 
Instruction, and Ri is then "cleared" by storing a zero in every character- 
position. 

As each character is received from the input device, it is stored in 
the right-most character-position of Ri, and the previous contents of Ri are 
shifted one character-position to the left, dropping one of the originally- 
r 1.0 red zeros. When the Register has been filled, a "putaway" is made automati- 
cally; that is, the contents of Ri are transferred to the proper partial -word 
field of the next Cell designated to receive information. That cell is the one 
whose address is currently stored in Rp. After the putaway has been made, Ri 
is cleared, ready to receive more data, (Rp) is augmented by 1, and input con-r 
tiriues , 

Ttvo tallies are automatically maintained during input, and appear in 
Cell ©00 when input terminates. 

Putaway-count in @00;86 . This field is cleared before input starts, 
and is augmented by 1 when each putaway is made. When input terminates, this 
field holds the number of Cells into which information was stored during input, 
as an address-type number. 

Character-count in ©00:33 . This tally is maintained in a 2-character- 
long working- register (Rt), and is transferred, right -justified, to ©00:33 after 
each putaway, replacing the tally generated by the previous putaway, 

Rt is cleared before input starts, and is augmented by 
1 as each succeeding character is received into Ri. 
When (Rt) equals the current length of Ri, then Ri is 
full. A putaway is made, (Rt) — >-@00:33, right -justified, 
and Rt is cleared in readiness for continued input. 
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VJhen input terminates, ©00:33 holds the number of input 
characters contained in the last putavra.y. 

The input process may be illustrated by the following diagram, 
which shov/s Ri set to its full 10-character length, and successive put- 
aways being made to the 90-field of Cells 647, 648, &c. 



Ready to start 

Fiist character read 

Next character read 

Next character read 

Next 7 characters read 

Contents of Rt equals the 
length of Rl (Ri is full) 
(Ri;SO) — 647:90 
(Rt:10) — ©00:33 

Next character read 

Next character read 

Next 8 characters read 

Contents of Rt equals the 
length of Ri (Ri is full) 
(Ri:90) — <- 648:90 
(Rt;10) — ©00:33 

Next character read 

And so on---- - - 



©00 R_t 

9876543210 10 



R_p 
2 10 



R i 
9876543210 



ei 



©1 



[0_0J 

EH 
CIEAIED 



6 47 0000000000 



©1 



[oT] 
[To] 

CLEJtllEO 



OOOOOOOOOA 



|oooooooo a"b] 



OOOOOOOABC 



ABCDEFGHIJ 



0000000000 



OOOOOOOOOK 



OOOOOOOOKL 



KLMNerPQRST 



©1 



64 9 0000000000 



[FT] 



ooooooooou 



DATA BEING READ 

ABCDEFGHIJKLMNBPQRSTUVWXYZ . 
BCDEFGHIJKLMN8PQRSTUVWXYZ. . 
CDEFGHIJKLMNePQRSTUVWXYZ. . . 
DEFGHIJKLMN9PQRSTUVWXYZ. . . 
KLMN9PQRSTUVWXYZ. . . 

KLMN9PQRSTUVWXYZ. . . 
LMNOPQRSTUVWXYZ. . . 
MN8PQRSTUVWXYZ. . . 
UVWXYZ. . . 



UVWXYZ. . 
VWXYZ. .. 



Several control codes are available, and affect the input 



process: 



"Putaway" code ('IX") mil cause the putaway function to be 
performed, even though Ri may not be completely full. If Ri is empty, 
the "Putaway" Code vdll alvraj^s be ignored. The operation of the "Put- 
aT^^ay" Code is shovm in the follovdng diagram: 



Ready to start 

First character read 

Next 6 characters read 

Next character read is 

"Putaway" . 
(Ri:90)— 501:90 
(Rt:10) — ©00:33 

Next character read 

Next 3 characters read 

Next character read is 

"Putaway" . 
(Ri:90) — 502:90 
(Rt:10)^ ©00:33 

Next 10 characters read 

Contents of Rt equals the 
length of Ri (Ri is full) 
(Ri:90)— 503:90 
(Rt:10) — ©00:33 

Next character read is 

"Putaway" . 
Since Ri is empty, 

"Putaway is ignored. 

Next character read 

And so on -------- 



©00 R t R p 
9876543210 10 210 



©1 



Its- 7 



©1 




\r\0 2]:;;s 


mm^i 


©1 


tS:|0 3J:V 


mmM 




itJo 3 If 


umm 



[TT] 



jo 0p?i:}0iK.S:;>;.:] |0 0| |5 1| 



CLEARED ©1 



|0 0| |5 2[ 



Qima ©1 



|0 0| |5 3| 


CLEARED ©1 


|0 o| l5 4| 




|0 0| |5 4| 



R_i 
9876543210 



0000000000 



OOOOOOOOOA 



OOOABCDEFG 



0000000000 



OOOOOOOOOH 



OOOOOOHIJK 



0000000000 



LMNePQRSTU 



0000000000 



0000000000 



ooooooooov 



DATA BEING READ 

ABCDEF&'HIJK-'LMNePQRSTU-'VW . 
BCDEFG-'HIJK-'LMNOPQRSTU^VW. . 
-»'HIJK--'LMN9PQRSTU-'VW. . . 

HIJK^LMNSPQRSTU-'VW. . . 
IJK-'LMNaPQRSTU^VW. . . 
-'LMNBPQRSTU^'VW . . . 



LMNSPQRSTU^'VW. . . 
-'VW . . . 
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Compute" Code ("^") causes the putaway function to be performed 
(unless Ri is empty), and tenninates input. The Processor then resumes execu- 
tion of the program, selecting its next Instruction from the address stored in 
^00s20. 

Upshift and DovmshJ-fts Some code-systems conventionally used with 
punched paper-tape are "shifting" codes. That is, two different characters in 
the code may be located on the same key of the tape-punching keyboard, and be 
represented by the same configuration on the paper-tape. When a tape punched 
in such a code-system is read by the Processor, many of the configurations 
must be interpreted as one of two possible characters, according to the shift- 
position of the tape-punching keyboard at the time that configuration was 
punched. 

Therefore, all devices which punch such a "shifting" code will punch 
distinctive configurations on the paper-tape whenever the "upshift" and "down- 
shift" keys are struck. The Processor recognizes these configurations as 
input-control codes, and switches back and forth from one set of decoding cir- 
cuits to another as these codes are detected. 

The following input-control codes are used principally when typing 
on the Console Type^/riter, or when recording programs on punched paper-tape: 

. "a" ("new putaway address follovrs")s This code causes the Processor 
to store the next three input characters in Register Rp, On the typewriter, 
this code is obtained by striking the "A" key in upper shift (see Typewriter 
Code^ in Chapter VI). 

"2" ("new starting address follov/s")? This code causes the 
Processor to store the next three input characters in ^00s20, On the type- 
writer, this code is obtained by striking the "C" key in upper shift (see 
Typevn^iter Code, in Chapter VI). 

In detail, "a" and "c" perform the following functions: 

- Clear Ri and Rt. Any previous contents of these registers 
is discarded. -«., 

- (Rp) is not disturbed, at this point, 

- Set the length of Ri to 3 characters. 

- When (Rt) = 3 (i*e. Ri is full), the contents of Ri are 
transferred to Rp or to ^00s20, as appropriate. 

- The length of Ri is reset to that specified by the HALT 
or READ PAPER TAPE Instruction., Ri and Rt are cleared. 

- If a "putaway" code is received during this operation, 
the Processor will error-halt. 

- If a "compute" code is received during this operation. 
Ri and Rt are cleared (their contents being discarded), 
and the Processor resumes execution of the program, 

- Note that the tallies in ©002 86 and @OOs33 are not 
disturbed by an "a" or "c" operation. 

"M" ("clear")? This code causes Ri and Rt to be cleared, and their 
contents discarded; it furnivshes a convenient method of correcting typing errors 
If "clear" occurs during an "a" or "c" operation, the length of Ri is also reset, 
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In addition to these control codes, ■which can be punched into the 
paper-tape or entered on the Console Typewriter, there are two circumstances , 
which can arise during the READ PAPER TAPE operation, which the Processor 
interprets as thoiigh it had received control codes. 

Parity error ; Many of the codes which are -used with punched .paper- 
tape are "self -checking" or "parity" codes. That is, every character in such 
a code must have an even number of holes if "even-parity" is used, or an odd 
number of holes if "odd-parity" is used. 

The Paper-tape Reader has the ability to check such parity codes. 
If it should detect an error in parity, it will store the character "x" 
( code 11 1111) in Ri instead of the garbled character, and there will then 
be an immediate putaway. The input operation teniiinates, and the Processor 
resimies execution of the program, selecting its next Instruction from address 
J3. 

That portion of the program which the programmer has stored at J3 
has available to it the two tallies in @00;S6 and @00:33; it can thus pro- 
vide for reading the rest of the "transaction and, if desired, typing it out 
on the Console Type>7riter, discarding it from the input, and resume the 
reading of the paper-tape. The operator may then correct the transaction 
by comparing it with the original data, and arrange for its re-entry later* 

End of Tape : The Paper-Tape Reader has the ability to distinguish 
between broken tape (which causes the Reader to error-halt) , and end-of- 
tape. 

Detection of the physical end of the tape causes a putaway (unless 
Ri is empty), ter-mination of input, and resumption of the program. The 
Processor selects its next Instruction firom address J2. 

This ability to identify the end of the tape, and to cause a unique 
branch in the program, eliminates the necessity for punching a "sign-off" 
code at the end of the input, and further eliminates the necessity of having 
the program test every transaction for this sign-off code. 
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TABLE IV-1: 



Language Code 





NUMERIC 














NUMERIC BITS 














ZONE 


VALUE OF 




























BITS 


ZONE BITS 


0000 


0001 


0010 


0011 


0100 


0101 


0110 0111 1000 1001 


1010 


1011 


1100 


1101 


1110 


nil 


00 


Illl 





1 


2 


3 


4 


5 


6 7 8 9 


@ 


t 


SPACE 


& 


• 


» 


01 


■111 


— 


A 


B 


C 


D 


E 


F G H 1 


n 


A 


m 


n 





P 


10 


lllll 


+ 


J 


K 


L 


M 


N 


& P Q R 


% 


£ 


$ 


( 


) 


/ 


11 


«rf 


♦ 


# 


S 


T 


U 


V 


W X Y Z 


d 


s 


u 


V 


w 


X 



TABLE IV-2: Modification of first word of Instruction by Index Register 



S-value 
4 
2 
1 



Sum 



A syllable modified 
N syllable modified 
J syllable modified 
Determines combination 
of syllables modified. 



S-values of syllables 



4 

J L 



2 

J i_ 



If S = 0, no Index Register is used, and R is irrelevant. 



TABLE IV-3: Interchange of syllables in «00 



(^00) before operation 



■-■■-t \. .'.... -A 



Q 

-J L 



positive 
negative 



(^00) after operation 



no branch 



iw""!' 



IM<. ^ ■ 



.■y....-...tt.„.=i.. 



,.ft h 



P 

J L 



Q. e , 2 



Q.®.^ 



branch 



rrr 




Sx-X-SJWSft 


P 

» 1 


J 

1 1 


E. 


. ^' 


SiJiiill 




'"^i 


*- 


Bill 


Q e 2 


J 
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READ PUNCHED CARDS 

This Instruction permits the reading of SO-coltmm cards 
directly into the Processor Memory at extremely high speed. 

As many cards as desired may be read with a single Instruction, 
and either all, or a portion of, each card may be read. 

If the voltinie of input -warrants the additional equipment, cards 
may also be transcribed "off-line" to Magnetic Tape through the Universal 
Converter, as described in Chapter VI - PERIPHERAL EQUIPMENT. 
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INSTRUCTIO?/ FORMAT: 
9 6 7 6 5 4 3 



0£_ 


.. JL Jl 4 


1..... 1.. 

N 
1 1 


,J , 




V 


M 


S 


R 


i:;:;:;:;:;i;:;:i:::;:i:i:::::::::::: 




w 



Operation: READ PUNCHED CARDS (^ 

Operation Code: * 



DEFINITIONS: 

Op: operation code. 
M; automonitor level: 



0, 1, 2, 3. 



S: selects syllables for modification 
by Index-Register 'OOR, 

R: designates OOR as Index-Register. 

A: base of address in which first 10 

colimins of first card are to be stored. 

N: as modified by (OOR), specifies the 
number of cards to be read. 

W: number of Memory cells to be filled 
from each card. (i.e. - read the 
first low columns from each card.)_ 



000 - N - Z99 



N = means "do nothing" 

- W ^ a 
W = means pass N cards 
■without reading. 



J: base of address of next Instruction, 
if fewer than N cards have been read 
and no more cards remain to be read. (See note) 

V: variation designator: 

only the sign of V is relevant. 



NOTE ; There is a LAST BATCH Switch on the Card Reader. 

Switch in NO position: If hopper empty and fewer than N cards read, 

the Processor will wait, and resume execution 
of the Instruction when more cards have been 
put into the hopper, and the "Operate" button 
on the Card Reader has been pressed. 

Switch in lES position: If hopper empty and fewer than N cards read, 

the Instruction will terminate, and the next 
Instruction will be selected from the address 
specified by J. 

TALLY IN ©00 : 

After termination, (©00: S6) contains number of putaways made. 
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DESCRIPTION OF: READ PUNCHED CARDS 

The Processor starts the High-Speed Punched-Card Reader, which then 
continues to mn until: 

a) M cards have been read, after which the Processor executes 
the next Instruction in the program. 

b) The Input Hopper is empty (and/or the Output Hopper is full). 
Depending on the setting of the LAST BATCH Switch, the 
Processor either waits for the Reader to be reloaded; or 
terminates the operation and selects its next Inst miction 
from the address specified by J. 

The first 10 columns of the first card are read into Cell CAJ, 
mth the character punched in column 1 appearing in character-position 9, etc, 
The next 10 columns into Cell CA © X] , and so on until ¥ Cells have been 
filled from the first card. The remainder of the card is passed through the 
Reader without storing any information in Memory. The first 10 columns of 
the next card are read into Cell [A © Wj, and so on until the operation 
terminates . 

Blank columns on any card are read as "spaces". 

The conventional punched-card code has been extended, so that all 
64 characters of the Processor's Language Code can be represented in cards. 

If the Reader's self -checking circuits detect an error, or an 
illegal configuration punched into a card, it will error-halt. 



Punched Cards may be transcribed to Ifegnetic Tape "off-line" 
through the Universal Converter. For details of Card-Reader operation, 
Converter operation, and the extended Punched-Card Code, see Chapter VI 
PERIPHERAL EQUIPMENT. 



NOTE : It is possible that columns 81 and 82 of an "80-column" card 
might have been punched. These columns are not read, 
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AUTOMONITOR 

As an aid to Code-Checking, or "Debugging", two techniques are 
available for selectively monitoring programs: 

MONITORING BY PROGRAM LEVEL 

Every Instruction contains a digit (designated as M) which 
specifies the level of monitoring to which that Instruction will be subject. 
Four levels (O, 1, 2, 3) are available, and after a program has been 
written, the programmer will assign a monitoring level to each Instruction 
in the program. Major check-points will be assigned level 3, lesser check- 
points levels 2 and 1, down to the individual Instructions between check- 
points, which will be assigned level 0. 

A Program Level Monitor Switch is provided on the Console, with 
positions OFF, 0, 1, 2, 3. When this switch is in the OFF position, no 
Program-Level Monitoring will take place. When the switch is set to one 
of the numbered positions, every Instruction whose Monitor Digit has a 
numeric value (modulo k) greater than or equal to the switch-setting, will 
be monitored. 

MONITORING BY ADDRESS LOOKUP 

A set of four Address Selection Switches is provided on the 
Console, and these switches may be set to any address in the Processor 
Memory. For the operator's convenience, these switches portray an address 
in its 4-digit numeric form, rather than as a condensed Address-Type Number, 
There is also an Address Monitor Switch with OFF and ON positions. When 
this switch is OFF, it will show a blue light, and no Address -Lookup 
Monitoring will take place. When the switch is ON, it will show a yellow 
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light, and the Processor vd.ll monitor every Instruction which requires 

a loolrap to the Memory location specified in the Address Selection Switches. 

An Address-Lookup occurs whenever the Processor selects? 

* Any word of the Instruction itself, 

"^ An Index-Register to modify the Instruction, 

^ An operand, 

''^f A location for storage of a result. 

Program-Level Monitoring and Address -Lookup Monitoring may be 
carried on independently or simultaneously, as the operator may choose. 
If the M-digit of any Instruction contains a negative character (a charac- 
ter with a l~bit in its sign-bit position), that Instruction will never be 
monitored by either method o 

It is important to provide complete flexibility, not only in the 
amount of information furnished during monitoring, and in the format in 
which the information will be presented, but also in the medium (console 
typewriter^ punched paper tape^ line printer^ or magnetic tape) in which 
the information will be recorded. In order to achieve this flexibility, 
the actual compilation and editing of the information is performed by 
means of a Monitoring Program^ which the operator stores in the Processor 
Memory before beginning to monitor o The Monitoring Programs may range 
from a simple tracing procedure which records only the address of each 
Instruction monitored, to a ©omplete printout of each Instruction in its 
coded form and also as modified by an Index-Register, the contents of the 
Index-Register^ the operands ^ and the results o 

The operator stores the Monitoring Program in the Memory, and 
plants the address of the fir^st Instruction of the Monitoring Program in 



the A-syllable of Cell ^01 (that is, in (^1:86 ). He sets: 

"»" The Program Level Monitor Switch, or the Address Monitor 

Switch, or both; 
-'^ The address Selection Switches, if they are to be used; 
^'^ A Monitor Run-Halt Switch, whose function will be described 

shortly. 

The operator then runs, in the usual manner, the main program, 
which is to be monitored. 

After executing each Instruction in the main program, and just 
before selecting the next Instruction, the Processor examines the two 
Monitoring Switches, to see if either of them is ON; if so, the Instruc- 
tion just completed is reviewed to see if it qualifies for monitoring. 
If the Instruction does not qualify for monitoring, the main program is 
resumed and the next Instruction is selected for execution in the usual 
manner. If the Instruction does qualify for Monitoring, the Processor 
automatically stores certain information about the Instruction, in the 
special Memory locations (^01 thro\:igh <tOU * and then inspects the setting 
of the RUN-HALT Switch, The stored information is in the following form: 





9 


8,7,6 


5,4,3 


2.1 

1 1 


001 




Address of Monitoring Routine 

(Previously stored by operator) 

1 1 


Address of next Instruction 

in the program 

1 1 


Address of the Instruction 
to be monitored 

1 1 


002 


Contents of First Word of Monitored Instruction, as Modified by (OOR) 

II II II 


003 


Contents of Second Word of Monitored Instructidn 

1 1 1 


004 


Contents of Index Register OOR 

II II 11 
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It must be observed that the information in Cells (jiOl through 
(^04 is compiled after execution of the monitored Instruction has been 
completedo If the Instruction changes itself (e<,go in Example 9 of 
"Normal" DISTRIBUTE^ page IV-J-12)^, it will be displayed as it appears 
after execution o 

After the information has been stored^ the next step depends on 
the setting of the Monitor Run-Halt Switch » 

If the Monitor Rim-Halt Switch is set to RUN^ it shows a yellow light; 
the Processor plants the address of the Monitoring Program 
((5fe01?86) into (jf:00§20 (the Sequence-Control Register), and then 
proceeds to execute the Monitoring Progranio The last Instruc- 
tion of the Monitoring Program must be written so that it plants 
the address of the next Instruction in the main program ((^01s53) 
into (^00s20^ so that the Processor ijnmediately resumes the main 
program o 

^^ "^h® Monitor Run-Halt Svritch is set to HALT^ it shows a blue light | the 
Processor halts immediately after storing the information in 
Cells (^01 through (^04^ and turns on the Console MONITOR HALT 
light o The address of the Instruction being monitored is dis- 
played as four arable digits in the Address Indication Lights 
on the Console o The operator may then change the settings of 
the Program Level Monitor S^d-tch^ the Address Selection Switches 
and/or the Monitor Run-=Halt Switch^ if he desires ^ and then press 
the START button^ whereupon the Processor will enter the Monitor- 
ing Program^ and then continue with the main program^ exactly as 
though the Monitor Run-Halt Switch had been set to RUNo 
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Or the operator may press the RESET button on the Console ^ 
which puts the Processor into the "Rest" state , and causes the REST 
light on the Console to be turned on in place of the MONITOR HALT 
light. The operator now may manually determine the next step, as 
described in Chapter VI, under CONSOLE OPERATION. 

Some of the options available to the operator at this point ares 

Start. If the START button on the Console is pressed, the Processor will 
resume execution of the main program . 

Printout . If the PRINTOUT button on the Console is pressed, the Processor will 
type on the Console Tjrpewriter the contents of whatever Memory location is 
specified by the Address Selection Switches o Before Printout, of course, 
these switches may be changed to designate any desired Memory location. 

Manual Input . By tjrping on the Console Typewriter, the operator may change 
the contents of any Memory locations he chooses. 

New "Start" Address . The operator may designate any Memory location as the 
address of the next Instruction, before he presses the START button to resume 
processing. He may wish to execute a special Monitoring Program for this 
part of the main program^ to monitor a different part of the main programi 
or to change to some other operation altogether. 
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OPERATOR'S CONSOLE CONTROL PANEL 

On all Control Panels -within the NCR 304 System, the display lights 
have been restricted to three colors "with^ generally ^ the following 
significance: 



lELLOW 


BLUE 


RED 


On 

Ready 
Operating 
Normal 


Off 

Not Ready 

Stop 

Non-Normal 


Alarm 



Whenever it appears that the distinction between the two states of a 
switch, as indicated by Yellow and Blue lights, is in any way ambiguous, 
the svjltch markings on the panel are underlined in the appropriate colors 



OPTION SWITCHES 



0-9 : These are examined by the TEST OPTION SWITCH Instruction, 

Each switch contains two colored lights: 
ON: Yellow 
OFF? Blue 



OPERATING SWITCHES 

RESET : Pressing this button removes the Processor from the 

MONITOR HALT, OVERFLOW HALT, or ERROR HALT state, and 
places it in the REST state. 

If any peripheral unit goes into Error Halt, the 
Processor will "hang up" . The operator should press 
the RESET button and bring the Processor to REST before 
resetting the peripheral unit. 

If the RESET button is pressed during Processor operation, 
it will place the Processor in the REST state, but it will 
not be possible to resume the program from that point. 

The RESET button is inoperative when the Processor is in 
the HALT or the TEST PANEL state. 
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START: 



When the Processor is in the REST state, pressing 
this button causes it to start executing the program. 

When the Processor is in the HALT state, pressing 
this button causes it to execute the next Instruction in 
the program, and then halt again (single-step operation). 
At each halt, the ADDRESS INDIGATION lights display the 
address of the next Instruction in the program. 

When the Processor is in the MONITOR HALT state, pressing 
this button causes it to start executing the Monitoring 
Program, 

The START button is inoperative in all other circumstances. 

The START button shows a yellow light while the Processor 
is executing a program. 



PRINTOUT: 



This button is operative only when the Processor is in 
the REST or the HALT state. At that time, pressing this 
button will cause the contents of one Memory Cell to be 
typed automatically on the Console Typewriter; that Cell 
is the one whose address is specified in the ADDRESS 
SELECTION switches. 



OPERATOR HALT: 



Pressing this button will cause the Processor to halt the 
program as soon as the current Instruction is completed, 
and enter the HALT state, at which time this button will 
show a red light. 

While the Processor is in the HALT state ^ the only controls 
which can be operated ares 

Power ON-OFF buttons, which are not operative at 
any other time. 

The START button, which will (in this circumstance) 
cause single-fetep operation. 

Pressing the HALT button the second time will turn off the 
red light, and place the Processor in the REST state. 

After an OPERATOR HALT, the ADDRESS INDICATION lights show 
the address of the next Instruction in the program. 
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STATUS LIGHTS 



REST: 



Blue ligl;it. The Processor enters this state: 

- As the result of a HALT Instruction in the program. 

The ADDRESS INDICATION lights display the 
address specified by A of the Instruction. 
~ As the result of pressing the RESET button. 

- As the result of pressing the HALT button a 

second time. 



MONITOR HALT: 



Blue light. While the Automonitor is being used, vdth 
the MONITOR RUN-HALT switch set to HALT, an Instruction 
has been selected for monitoring. 

The ADDRESS INDICATION lights display the address of the 
Instruction to be monitored. 

If the START button is pressed, the Processor vdll enter 
the Monitoring Program. If RESET, and then START, are 
pressed, the Processor will resume the main program, 
•without monitoring. 



OVERFLOW HALT: 



Red light. An Instruction has set the Overflow Alarm, 
and the next Instruction is not TEST OVERFLOW. 



The ADDRESS INDICATION lights give no useful information. 

The operator may PRINTOUT the contents of Cell ^00, and 
subtract 2 from the contents of its C-^syllable to obtain 
the address of the Instruction which detected the overflow. 



ERROR HALT: 



Red light. One of several things has happened: 

Either the Processor is attempting to execute a non-existent 
Operation Code, in which case the ADDRESS INDICATION lights 
display the address of the impossible Instruction; 

Or the programmer has made a serious error, such as specifying 
an impossible Memory address, or a non-existent Controller; 

Or the Processor's self -checking circuits have indicated that 
some component of the system has failed. 

In the last two cases, the ADDRESS INDICATION lights 
will display the address of the last Memory lookup. 
Detailed information as to the source of the error is 
shown on the Engineer's Test Panel. 
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TEST PANEL : Blue light. The Processor is under the control of the 

Engineer's Test Panelj and is not available to the 
operator. 



CLASSIFICATION LIGHTS 



These are two rows of yellow lights ^ which flicker as each Instruction is 
executed, indicating the classification to which the current Instruction 
belongs; after any halt, the classification of the last Instruction exe- 
cuted is shown. These classifications correspond to the color-coding of the 
index tabs in Chapter IV f 

Yellow tabs Arithmetic 

Blue tabs Decision 

White tabs Input (Halt, Read Paper tape, Read Cards) 

Output (Print, Type/Punch) 
Dark Green tabs File On~Line (Read Tape, Write Tape, Write-Copy-Read) 

File Off -Line (Write-Copy, Rewind) 
Light Green tabs Editing 
Pink tabs Data-Handling 



ADDRESS INDICATION LIGHTS 

These lights display, as 4 arable numerals, every address -lookup performed 
by the Processor. Addresses of the "Special" Cells are shown as 3 characters, 
using the first, third and fourth lights » 

The significance of the address displayed in these lights after any halt is 
stated under the description of each of the STATUS LIGHTS, 



ADDRESS SELECTION SWITCHES 



The operator may set into these switches the address of the Memory Cell 
whose contents he wishes typed out on the Console Typewriter, when he 
presses the PRINTOUT button. 

These switches are also used to designate a specific Memory Cell for the 
ADDRESS MONITOR. 

An address is set into these switches as a 4-digit number; 
addresses of the "Special" Cells are set as 3 characters, 
using the first, third and fourth switches. 
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ADDRESS MONITOR? 



MONITOR SWITCHES 

(See Chapter V) 

This switch contains two colored lights; 
ON: Yellow 
OFF: Blue 



PROGRAM LEVEL 
MONITORS 



The setting of this switch determines the level of 
Monitoring, in connection with the M-digit of each 
Instruction in the program. 



MONITOR RUN-HALTj 



This switch contains two colored lights? 
RUNS Yellow 
HALTS Blue 

The words RUN and HALT on the panel are underlined in 
yellow and blue, respectively , to remind the operator 
of the significance of the colored lights. 

If no monitoring is being performed, this button shows 
no light. 



POWER SWITCHES 



All Power ON-OFF switches are interlocked with the HALT button, and are 
operative only when the Processor is in the HALT state. 

Power in peripheral units may be turned on only after Processor power is on. 
When Processor power is turned off, all peripheral units are turned off also, 



PROCESSOR POWER : As soon as the ON button is pressed, the Processor enters 

an automatic warmup-test cycle and the lights in the 
OPTION SWITCHES are turned on. 

When the Processor has completed its self -testing operation, 
the red light in the HALT button goes on, indicating that 
the Processor is in the HALT state. 

Pressing the HALT button the second time (the first time 
occurred just before the power was turned off) places the 
Processor in the REST state, and processing may begin. 
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PERIPHERAL UNIT Once the Processor power has been turned on, power may 
POWER : then be turned on in the peripheral \mits. Each unit is 

represented on the Console by: 

an ON button; 

an OFF button; 

a BUSY light. 

When power is first turned on at each unit, its ON button 
will show a blue light (not ready), while that unit goes 
through its own warmup-test cycle. 

- When the unit has completed its self -testing operation, 
its ON button will show a yellow light ( ready) . 

Whenever the unit is actually in use, its yellow BUSY 
light will be turned on. 

If the unit should, for any reason, go into an Error-Halt, 
its ON button will show a red light. 



INPUT-OUTPUT CODE Selection among t^ree codes on the Paper Tape Reader, and 
INDICATORS : between' two codes on the Paper Tape Punch, is made manually 

at each unit. 

In order that the Console operator may conveniently monitor 
these selections, they are displayed as yellow lights next 
to the power buttons for the respective units. 
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OPERATOR'S CONSOLE 

CONTROL PANEL 
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OPTION 

SWITCHES 



ELECTRONIC DATA 
PROCESSOR (304) 




RESET 




START 




PRINTOUT 




HALT 



REST 



MONITOR 
HALT 



OVERFLOW 
HALT 



ERROR HALT 



TEST PANEL 



ARITH 



INPUT 



FILE 
ON LINE 



EDIT 



DRUM 



DECISION 



OUTPUT 



FILE 
OFFLINE 



DATA 



© 





ADDRESS INDICATION 




ADDRESS SELECTION 






ADDRESS MONITOR 
OFF-ON 



PROGRAM LEVEL 
MONITOR 



MONITOR 
RUN-HALT 




ON 




OFF 
PROCESSOR 



CODE 1 



CODE 2 



BUSY 




ON 




OFF 
PRINTER 



CODE BUSY 




ON 




OFF 
PAPER TAPE READER 



BUSY 




ON 




OFF 
CARD READER 



CODE BUSY 




ON 



CODE 1 




OFF 
PAPER TAPE PUNCH 



BUSY 




ON 




OFF 



BUSY 




ON 




OFF 



BUSY 




ON 




OFF 



BUSY 




ON 




BUSY 




ON 




OFF 



BUSY 




ON 




OFF OFF 

MAGNETIC TAPE CONTROLLERS 



BUSY 




ON 




OFF 



BUSY 




ON 




OFF 



OPERATOR'S CONSOLE 



CONTROL PANEL 



PAPER TAPE INPUT-OUTPUT 



NCR TYPEWRITER CODE 

(Odd-Parity) 



TYPEWRITER KEY 


LOWER 
. SHIFT 


UPPER 
SHIFT 





) 


1 


1 


2 


£ 


3 


# 


4 


$ 


5 


% 


6 


/ 


7 


& 


8 


* 


9 


( 


A 


^ ® 


B 


B 


C 


c ® 


D 


d 


E 


E 


F 


F 


G 


G 


H 


H 


1 


1 


J 


J 


K 


K 


L 


L 


M 


m 


N 


n 


o- 


s- 


P 


P 



CHANNELS 



8 


7 


6 


5 


4 




3 


2 


1 




O 






o 






o 




















o 
















o 






o 












o 


o 














o 








• 










o 




o 




o 










o 


o 
















o 


o 


o 










o 












o 






o 








o 




o 




o 










o 




o 




o 








o 










o 








o 


o 









o 



















o 











o 








o 






o 


o 






o 




o 






o 


o 


o 




o 




o 


o 
















o 


o 








o 




o 


o 












o 




o 


o 










o 








o 










o 


o 




o 


o 








o 










o 








o 




o 






o 








o 


o 






o 


o 








o 


o 


o 



TYPEWRITER KEY 


LOWER 
SHIFT 


UPPER 
SHIFT 


Q 


Q 


R 


R 


S 


s 


T 


T 


U 


u 


V 


V 


W 


w 


X 


X 


Y 


Y 


Z 


Z 


@ 


+ 


^ 


D 


- 


A 


• 


» 


SPACE 


SPACE 


PUTAWAY 
^ ® 


PUTAWAY 
-A^ ® 


COMPUTE 
> ® 


STOP 

3 @ 


CLEAR 

^ ® 


CLEAR 

u ® 


UP 
SHIFT ® 


UP 
SHIFT ® 


DOWN 
SHIFT ® 


DOWN 
SHIFT ® 


CODE 
DELETE @ 


CODE 
DELETE @ 


TAPE 
FEED @ 


TAPE 
FEED @ 


®-,r ® 


^ CARR _ 
© RET ® 


© TAB ® 


© TAB ® 


BACKSPACE 

® 



CHANNELS 



8 




6 


5 


4 




3 


2 


1 










• 


















• 








• 
















• 


















• 


• 














• 


















• 




• 














• 


• 
















• 


• 


• 










• 


















• 








• 






































































• 






































• 






O 












• 
















• 


• 








• 








• 


o 








• 








• 








• 


O 






• 


• 


• 


























e 






• 


• 


• 




• 




• 






e 


e 




DOES NOT PUNCH 



VI- CODES -1 



NOTES 

Q) Input Controls. These exercise control 
functions during input, and store no 
information in memory. 

(2) Typewriter controls. These have no 
function during input, and are ignored. 

(3) When punching with Programmed Formal 
from Processor or Converter 

w (code 11 1110) becomes TAB 

X (code n mi) becomes CARR RET 



n 
o 
O 

C/2 



PUNCHED CARD CODE 

INPUT-OUTPUT 



0123456789ABCDEFGHIJ K LMNeP QRS T U VWXYZ & • n-$ * / '%#@| + A?ii ( ) dsmne ouvvfx 

_ X XUXXXXXX X 

lllllllll 

lllllllll 

|000000000000000000000Q00000||||||||0 00000 §i|0 00 |01 |0 illOQOOOOlO 

1 1 1 1 11 1 1 11 1 11 11 1 1 1 1 1 1 1 1 1 1 1 1 1 1 n n 1 1 11 1 1 11 1 |i 1 1 11 11 1 1 1 1 1 1 11 1 nil; 1 

2 2 1 2 2 2 2 2 2 2 2 i 2 2 2 2 2 2 2 2 1 2 2 2 2 2 2 2 |2 2 2 2 2 2 2 2 2 2 2 2 2i 2 2 2 2 2 2 2 2 2 2 2 2 2 2 |2 l2 2 2 2^2 
333|3 3333333 |33333333|3333333|3333333|33 |33 |3 1333333 |3 1333333333 
4444|44444444|44444444|4444444|4444444|4 4|4 4|4|4 4444|4 4 444|4 44 44 

5 5 5 5 5 I 5 5 5 5 5 5 5 5 1 5 5 5 5 5 5 5 5 1 5 5 5 5 5 5 5 1 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 |5 |f 5 5 5 5 |5 5 5 |5 I 

6 6 666 6|6 66 66 66 6|6 6666666|6666 666|666 6 6 66666 6666666 6 66 6 6 66 86 66 6 66 
777 7 777|77 77 7 7 77 1 7 77777 7717777 777|7777 777777777777 177777 ||7 ||7 |7 
8 888 8 8 88|8 8 8 8888 818 88 888881888 8 888|8 8 lis lis nils 8 Ills 188 888 mil 
99999 999919 9999 99 9199 99999 91999 999 919 99999 99 999 999 999 9 1999999999 



X WILL NOT PRINT ON I.B.M. 026 PRINTING KEY PUNCH 



NOTE: The characters shown above, following "space", can be punched through a modifi- 
cation of the I.B.M. 026 Printing Key Punch, whereby these characters have been assigned 
to the number-shift position on the following keys: 

KEY REQTA FDSGNHZCVWX 
CHARACTER +A^ £ ( ) d smn e p u vw^x 

The I.B.M. 523 Summary Punch can also be modified to permit punching these characters 
from the Universal Converter. 



PAPER TAPE INPUT-OUTPUT 



I.B.M. 046-047 O-CHANNEL CODE 

(Orid-I^arity) 
CHANNELS 



CHARACTERS | 


046-047 


304 








1 


1 


2 


2 


3 


3 


4 


4 


5 


5 


6 


6 


7 


7 


8 


8 


9 


9 


A 


A 


B 


B 


C 


C 


D 


D 


E 


E 


F 


F 


G 


G 


H 


H 


1 


1 


J 


J 


K 


K 


L 


L 


M 


M 


N 


N 





O 


P 


P 


Q 


Q 


R 


R 


S 


S 


T 


T 


U 


U 


V 


V 


W 


Wo 



8 


7 


6 


5 


4 


. 


3 


2 


1 


EL 


X 





V 


a 




4 


2 


1 



















o 
































O 










o 








e 


e 














O 












o 






o 




a 








o 






o 


o 
















o 


a 


o 










o 
















9 


o 








e 




o 


o 












o 




o 


o 










o 






o 


o 


o 








o 


o 




o 


o 








o 








o 


e 


o 






e 




o 




o 


o 


o 






o 


o 






e 


o 








e 


o 


e 




o 


o 




o 












o 


o 


o 


o 








o 




o 




o 










o 




o 




o 








o 






e 












o 


o 




o 




o 






o 








e 










e 




o 




o 










o 


e 






• 




o 






o 


o 


e 




o 




o 


o 












e 






o 








o 






o 


o 








o 








o 










o 


e 






o 


o 






o 










o 








o 




o 






e 








o 


o 





NCR 
IBM 



CHARACTERS ] 


046-047 


304 


X 


X 


Y 


Y 


Z 


Z 


. 


* 


» 


1 


SPACE 


SPACE 


- 


- 


8c 


& 


@ 


@ 


P.I. 1 


^ 


n 


D 


p. 1. 2 


A 


P.I. 3 


+ 


% 


% 


P.I. 4 


£ 


$ 


$ 


E.G. 1 


( 


E.G. 2 


) 


/ 


/ 


* 


* 


# 


# 


P. 1.5 


d 


P. 1.6 


s 


S.P. 1 


PUTAWAY 
CD 


S.P. 2 


COMPUTE 


P. 1.7 


® ® 


END OF LINE 


® 


ERROR 


® 


SKIP 


@ ® 


TAPE FEED 
CODE DELETE 


® 


CORRECTION 


® 


Gr 


® 



a 


7 


6 


5 


4 




3 


2 


1 


EL 


X 




V 


8 




4 


2 


1 








• 






• 


a 


• 








• 


• 


















• 








• 




• 






• 






• 


• 








• 


• 






• 


• 








• 














• 


















• 


• 


• 


















• 


















• 








• 






• 


• 


• 














• 












• 








• 










• 








• 




. 














» 


• 










e 




• 




• 








• 


• 










• 






• 








• 










• 


• 






O 


• 










• 




• 






























• 


• 




• 


• 












• 




e 




• 










• 




• 


• 


• 








• 






• 


• 










• 




















• 


• 




















• 














• 






• 


• 














• 


• 


• 










• 








• 










• 




• 




o 













NCR 
IBM 



NOTES 

(Jj Input Controls. These exercise control functions during input, and 
store no information in memory. 

(2) These have no function during input, and are ignored. 

^) When punching with Programmed Format from Processor or Converter 

w (code 11 1 nO) becomes SKIP 
X (code 11 nil) becomes P.I. 7 

VI— CODES— 3 



PAPER TAPE INPUT-OUTPUT 



TELEGRAPHIC CODE 

( No n- Parity) 



n 
o 
O 

H 
CD 



CHARACTERS 


TELEGRAPH 
LETTER 
SHIFT 


304 


A 


A 


B 


B 


C 


C 


D 


D 


E 


E 


F 


F 


G 


G 


H 


H 


1 


1 


J 


J 


K 


K 


L 


L 


M 


M 


N 


N 


O 


Gt 


P 


P 



CHARACTERS 


TELEGRAPH 
FIGURE 
SHIFT 


304 


- 


- 


? 


COMPUTE 
© 


: 


+ 

® 


$ 


$ 


3 


3 


\ 


PUTAWAY 
® 


& 


& 


£ 


^ ® 


8 


8 


f 


* 
® 


( 


( 


) 


) 


• 


• 


» 


1 


9 


9 









5 4 '_2 2 \_ 

12*345 

• • • 

• • • 

• • • • 

• • • 

e • • • 

• • • • 

• • o 

• • • 

• • • • 

• • • • • 

• • • 

• • • • 

• • • 

• • • • 



NCR 
TEL. 



CHARACTERS 


TELEGRAPH 
LETTER 
SHIFT 


304 


Q 


Q 


R 


R 


S 


s 


T 


T 


U 


U 


V 


V 


w 


w 


X 


X 


Y 


Y 


z 


z 


SPACE 


SPACE 


FIGURE 
SHIFT 


FIGURE 
SHIFT ® 


LEHER 
SHIFT 


LEHER 
SHIFT ® 


TAPE 
FEED 


® 


LINE 
FEED 


® © 


CARR 
RET 


© ® 



CHARACTERS 


TELEGRAPH 
FIGURE 
SHIFT 


304 


1 


1 


4 


4 


BELL 


® © 


5 


5 


7 


7 


1 


□ ® 


JL. 


2 


1 


/ 


6 


6 


ti 


^ © 


SPACE 


SPACE 


FIGURE 
SHIFT 


FIGURE 
SHIFT ® 


LEHER 
SHIFT 


LEHER 
SHIFT ® 


TAPE 
FEED 


© 


LINE 
FEED 


® ® 


CARR 
RET 


® ® 



CHANNELS 



5 4 •_3 2 1^ 

1 2 •_ 3 4 5 

• O • • • 

• • • 

• • • 

e 

• • • • 

• • • • • 
« • • • 

• • • • • 

• • • • 

• • • 

• • • • • 

• ••••• 



NCR 
TEL. 



NOTES 

Q) Input Controls. These exercise control functions during input, and store no information in memory. 
The character "?" is interpreted as COMPUTE CODE. 
The character "!" is interpreted as PUTAWAY. 

(2) These have no function during input, and are ignored. 

(^ When punching with Programmed Format from Processor or Converter 
^-^ w (code 11 1110) becomes LINE FEED 

X {code 11 1 1 1 1) becomes CARR RET 

^4^ Every character in telegraphic code has been assigned a character in 304 code. As a result, the 
304 can communicate with any non-standard keyboard. 



PAPER TAPE INPUT 



CHARACTERS 


+ 


© 


1 


2 


3 


4 


5 


6 


7 


8 


9 


PUT A WAY 


© 


COMPUTE 


® 


TAPE FEED 


© 


V 


— 


A 


B 


C 


D 


E 


F 



KIMBALL 

PUNCHED-TAG CODE 

(Non-Parity) 

CHANNELS 



7 


6 


5 


4 




3 


2 


1 








7 




4 


2 


1 








O 




O 




















o 














O 
















o 


o 












O 
















o 




o 












o 













O 
















o 








o 








o 















O 








o 








0- 






o 


























o 
















o 



















o 




o 


o 














o 


o 


o 








o 









o 








o 




o 


o 


o 








o 




o 




o 






o 


o 











NCR 
KIMBALL 



When using NCR 

461-3 Recorder 

(single program, 

fixed diode-board) 

the following codes 

are read out from 

positions: 



S-2 



S-3 



S-9 



S-0 



S-1 



DENNISON 

PUNCHED-TAG CODE 

(Even-Parity) 

CHANNELS 



® 



7 


6 


5 


4 




3 


2 


1 






V 


7 




4 


2 


1 








• 




• 










o 










• 






• 








• 



















• 






• 






• 
















• 




• 












• 


• 








e 


9 

























• 








• 






• 








o 


O 




• 




• 






o 


• 




• 


• 


























o 




e 


• 


• 






o 


• 






• 


• 






o 






• 


• 


• 






e 


























• 














• 














• 








• 




• 











NCR 
DENNISON 



© 



NOTES 

Qj Input Controls. These exercise control functions during input, and store no information in memory. 

^) These have no function during input, and are ignored. 

^) Whenever the parent machine reads a "zero", the character " + " will be punched into the paper 
tape. This will enable the programmer to verify, in every case, that a field of the proper length has 
been read into the Processor. The first Arithmetic operation performed on each field within the 
Processor will, of course, replace every " + " with a "zero". 

(^ All of Kimball Code, and Dennison Code down through the letter "A", may be used for 5-channel 
telegraphic transmission from outlying data-origination points to the central Data-Processing Cente**. 



VI -CODES -5 



PAPER TAPE INPUT 
CASH-CONTROL CODES 



Non-Parity 

May be punched with 

Kimball Tags 



Even-Parity 

May be punched with 

Dennison Tags 



CHANNELS 



CHANNELS 



CHARACTERS 



+ 



® 



PUTAWAY © 



COMPUTE ® 



TAPE FEED 



8 


7 


1 

6 


5 


4 




3 


2 


1 










• 




• 






• 
































• 




• 














• 
















• 






• 












• 


















• 


• 












• 










• 








• 


















• 






• 










• 








• 










• 






• 






























• 












• 






• 




















• 




• 


• 




• 












• 


• 




• 








e 






• 




O 








• 




• 


O 




• 








• 




• 












e 


• 











When using NCR 

461-3 Recorder 

(single program, 

fixed diode-board) 

the following codes 

are read out from 

positions: 



S-2 



S-3 



S-9 



S-0 



S-1 



8 


7 


6 


5 


4 




3 


2 


1 










• 




• 






• 






• 


















• 








• 




• 














• 










• 






• 






• 












• 


















• 


• 










• 


• 










• 








• 


















• 






• 




• 






• 


• 




• 












• 


• 




• 


• 






















• 








• 




• 


• 




• 






• 


• 






• 




• 






• 




* 


• 


• 










@ 












• 
































• 
















• 














• 











NOTES 

MJ Input Controls. These exercise control functions during input, and store no information in memory. 

^) These have no function during input, and are ignored. 

Qs) Whenever the parent machine reads a "zero", the character " + " will be punched into the paper 
tape. This will enable the programmer to verify, in every case, that a field of the proper length has 
been read into the Processor. The first Arithmetic operation performed on each field within the 
Processor will, of course, replace every "-{-" with a "zero". 

Cash-Control Codes are formed by substituting Channel 8 for Channel 1 in conventional codes. 
The Cash-Control Codes will normally be used only for input to the Data-Processing System, and 
should be specified for Cash Registers and for all other recording devices which provide mechani- 
cal control over the integrity of cash entries. 

By using the TEST READER CODE Instruction, the Processor program con guarantee that cash 
transactions are input on// in Cash-Control Code. Since the Tape-Punching Typewriter is incapable 
of punching in Channel 8, it cannot be manipulated to punch Cash-Control Code, and it is therefore 
impossible to simulate a cash-transaction paper tape with the Typewriter. 



VI -CODES -6 



PAPER TAPE INPUT 



NCR CASH-CONTROL CODE (EXTENDED) 

(Odd-Parity) 



TYPEWRITER KEY 


LOWER 
SHIFT 


UPPER 
SHIFT 





) 


1 


1 


O 


r 


3 


$ 


A 


5 


% 


6 


I 


7 


& 


8 


* 


9 


( 


A 


^ ® 


B 


B 


C 


^ ® 


D 


d 


E 


E 


F 


F 


G 


G 


H 


H 


1 


1 


J 


J 


K 


K 


L 


L 


M 


m 


N 


n 


O' 


©■ 


P 


P 



CHANNELS 



8 


7 


6 


5 


4 




3 


2 


1 




o 






o 






o 




O 
































o 




O 


o 












o 
















O 






O 


o 










o 








o 










o 







o 












o 


o 












o 










o 


o 






o 










o 


o 




o 














o 




o 








o 




o 






o 


































o 






o 






o 












o 






o 


o 




o 


o 




© 









o 






o 




o 


o 










o 






o 













o 


o 


o 
















o 


o 










o 




o 




o 










o 






o 


o 








o 






o 













o 










o 








o 


o 




o 


o 











o 


o 





TYPEWRITER KEY 


LOWER 
SHIFT 


UPPER 
SHIFT 


Q 


Q 


R 


R 


S 


S 


T 


T 


U 


u 


V 


V 


w 


w 


X 


X 


Y 


Y 


Z 


Z 


@ 


+ 


i 


D 


- 


A 


• 


» 


SPACE 


SPACE 


PUTAWAY 


PUTAWAY 
-^ ® 


COMPUTE 
> ® 


STOP 

~\ ® 


CLEAR 


CLEAR 
gj ® 


UP 
SHIFT ® 


UP 
SHIFT ® 


DOWN 
SHIFT ® 


DOWN 
SHIFT ® 


CODE 
DELETE @ 


CODE 
DELETE © 


TAPE 
FEED © 


TAPE 
FEED © 


CARR 
RET ^ 


CARR 
RET ® 


TAB (D 


TAB @ 


BACKJ 


)PACE 

® 



CHANNELS 



8 


7 




5 


4 




3 


2 


1 




• 






• 










• 








• 
























• 




• 


• 












• 
















• 






• 


• 










O 








• 


• 








• 


• 




• 












O 


• 












• 










• 


• 






• 














« 
















• 
















































• 






e 
















O 


















• 


e 


e 














o 


e 












• 




o 


• 




• 








O 










• 








• 




e 


o 


• 


• 






• 


• 






• 
















• 






• 






• 


• 






• 




• 






• 







DOES NOT PUNCH 



The complete Extended Code (equivalent to NCR Typewriter 
Code) is mechanized in the 360 Paper-Tape Reader, offer- 
ing a wide choice of identification characters when this Code 
is used with a keyboard machine and Paper-Tape Recorder. 



NOTES 

(Y) Input Controls. These exercise control 
functions during input, and store no 
information in memory. 

Q2) Typewriter controls. These have no 

function during input, and are ignored. 



VI -CODES -7 



MULTI-PURPOSE CONVERTER CONTROL PANEL 



POWER SWITCHES 



At the right side of the panel, in the upper row, are five power switches 
for the Converter and its peripheral units. From left to right, the switches 
control: 

Paper Tape Reader 
Punched Card Reader 
Printer 

Paper Tape Punch 

Converter and Magnetic Tape Handler 
(Controls for the Card Punch are 
mounted on its own cabinet) 

Each of the five units is represented on the Control Panel by: 

An ON button; 
An OFF button; 
A BUSY light. 

When the power is first turned on at any unit, its ON button will 
show a blue light (not ready), while that unit goes through its 
own warmup-test cycle » 

When the unit has completed its self-testing operation, its ON 
button will show a yellow light ( ready) . 

Whenever the imit is actually in use, its yellow BUSY light will 
be turned on. 

If the unit should, for any reason, go into an Error-Halt, its ON 
button will show a red light. 



OPERATION SELECTOR 



This dial switch selects any one of ten operations to be performed by the 
Converter: 

Paper Tape Reader to Magnetic Tape 

Card Reader to Magnetic Tape 

Card Punch from Magnetic Tape 

Paper Tape Punch from Magnetic Tape 

Printer from Magnetic Tape 



VI - 320 



Advance magnetic tape one record 
Backup magnetic tape one record 
Write a CRM-record on magnetic tape 
Erase magnetic tape to the end of the reel 
Search magnetic tape for a record corresponding to the 
Record Selection Svrltches, then Halt 



Paper Tape to Magnetic Tape; 



The inforaiation on the paper tape is transcribed to magnetic tape, 
character by character^ as 12-word records. 

The "putaway" code on paper tape has the same function as when the 
Processor itself is reading directly into Memory, except that put- 
aways on magnetic tape are left- justified. After a "putaway" code, 
the previous field w:l11 appear at the left end of the word on 
magnetic tape, with the rest of the word filled out with zeros to 
the right. 

The "compute" code on paper tape causes a putaway (unless the 
Converter' s Input Register is empty) , and then fills out the 
balance of the current recorxi on magnetic tape with zeros. 



Punched Cards to Magnetic Tape; 



Each card is transcribed to magnetic tape as a minimum-length 
10-word record. 

Column 1 on the card goes into the 99-field of the first word in 
the record, column 2 goes into the Sg-field, etc. Columns 11-20 
occupy the second word of the record, and so on for eight words. 
Then the Controller records two more words of "spaces" to com- 
plete the 10-word record. 



Magnetic Tape to Punched Cards: 



Eight v7ords of each magnetic tape record are delivered to the 
Card Punch (see description of Magnetic Tape Mode Switch). 

The plugboard of the Card Punch may be used for its conventional 
functions , 



Magnetic Tape to Paper TapeJ 



Twelve words of each magnetic tape record are delivered, character 
by character, to the Paper Tape Punch, starting with the 99--field 
of the initial word (see description of Magnetic Tape Mode 
Switch) . 

If the record is shorter than 12 (or 13) words, the Converter 
fills out the balance of the 12-word Punch Block with "spaces". 
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Magnetic Tape to Printers 



Twelve words of each magnetic tape record are delivered to the 
Printer (see description of Magnetic Tape Mode Switch). 

If the record is shorter than 12 (or 13) words., the Converter 
fills out the balance of the 12-word Print Block with "spaces" 



MAGNETIC TAPE MODE 



This dial switch is operative only during output operations ^ and it selects 
"edited" or "unedited" magnetic tape operation. 

For this purpose ^ an "edited" magnetic tape is defined as a tape 
on which every record has had its first word edited to contain a 
slew control in the 99-field (if the tape is to be printed) and 
a record identification in the SO-field., 

Operating in the "edited" mode^ the Converter delivers the 
second through the thirteenth word of every record to the 
Paper Tape Punch or the Print er^ and the second through 
the ninth word of every record to the Card Punch . 

When printing 3 all the slew controls described on page 
IV~X~3 are effective ^ except that there is no "branch" 
marker set by a "skip" code on the Printer's slew-control 
tape loop* Therefore, when editing for off-line printing, 
it is necessary to have the editing program count the lines 
on each page. 

For this purpose, an "unedited" magnetic tape is defined as a 
tape on which the records have not had their first words edited 
in this fashion., 

Operating in the "unedited" mode, the Converter delivers 
the first through the twelfth word of every record to the 
Paper Tape Punch or the Printer, and the first through the 
eighth word of every record to the Card Punch o 

The three positions 0, 1, 2 of this switch are differentiated 
only when printing o Since there is no slew control in each 
magnetic tape record, these positions govern the vertical 
spacing of the printer 5 they cause it to skip 0, 1, or 2 
lines after each printed line (that is, print single, double, 
or triple-space). On the Printer's slew-control tape loop, 
the configurations "skip" and "stop" retain their functions, 
and may be used in their conventional capacities, except for 
automatic end-of-page branch (see page IV-X-3) « 

When operating the Paper Tape Punch or the Card Punch, the 
three positions 0, 1, 2 of this switch have identical func- 
tions 5 any one of them specifies "unedited" tape, 
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OPERATING CONTROLS 



At the left side of the panel, in the second row, are five Operating Control 
Switches; 

OPERATE COWERTER : 

Pressing this switch causes the Converter to begin operating as 
defined by the Operation Selector Switch, the Magnetic Tape Mode 
Switch, and by the other Operating Control Switches. 

RESET CONVERTER ; 

Pressing this switch returns the Converter to the operating state 
after an Error-Halt. The red light in the Converter's Power On 
Switch will then be replaced by a yellow light. 

CONTINUOUS /SINGLE ; 

Yellow light; Continuous operation. The Converter will per- 
form the operation specified by the Operation Selector Switch, 
continuously. 

Blue light; Single-record operation. The Converter will per- 
form the operation for one magnetic tape record (i.e. one printed 
line, one punched card, etc.) and then halt. 

The five operations specified at the right side of the 
Operation Selector Switch are always single; they are 
independent of the state of this Control Switch. 

SELECTIVE OUTPUT ; 

Yellow light; No. The Converter delivers every record on the 
magnetic tape to the Printer, Paper Tape Punch, or Card Punch. 

Blue light; Yes<, The Converter delivers to the output device 
only those records in which the 80-field of the first word 
exactly corresponds to the settings of the Record Selection 
Switches. 

This Control Switch functions only when performing an 
output operation (Print, Punch Cards, Punch Paper Tape) 
from "edited" magnetic tape. 
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CRM: Yellow light: Halt, if the Converter encounters any magnetic 
tape record containing a CRM ("v" in the 44-field of the first 
word). Do not output the CRM-record. 

Blue light: Ignore the presence of a CRM in any record, 
treating it just like any other record. 

This Control Switch has no function when performing an input 
operation. 



STATUS LIGHTS 



At the left side of the panel, in the top row, are five Status Lights: 

HANDLER OR CARD PUNCH , OPERATOR ATTENTION ; Blue light. 

The Handler is at the end of the tape (positioned on the trailer), 
or else it has finished rewinding (positioned on the leader). 

In the Card Punch, either the input stacker is empty, or the 
output stacker is fiill. 

PAPER TAPE READER , MEDIA ERROR : Blue light. 

The Paper Tape Reader has encountered a punched configuration 
which does not meet the (odd or even) parity requirement of the 
code being read. 

The character "x" (code 11 1111) is substituted for the illegible 
character on the magnetic tape, and reading continues until the 
record is complete. Then the operation halts, and this blue 
light is turned on. 

The recommended procedure is for the operator to record a CRM- 
record on the tape (following the record containing the illegible 
character), and then to resiime the operation. When this magnetic 
tape is later read into the Processor, the program must take 
account of this possibility. 

This procedure is based on the fact that, if the Paper Tape 
Reader finds the same configuration punched into the tape, at 
both of its duplicate reading stations, and if that configuration 
does not meet parity, this can only be the result of an incorrect 
punching of the tape, and there is no point in attempting to 
re-read o 



HANDLER ERROR HALT: Red light. Reset at the Handler. 
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HANDLER SEARCH HALTs Blue light. 

When performing the Search-Halt Operation, the Handler has found 
the desired record, and has therefore halted. 

HANDLER CRM HALT? Blue light. 

The Handler has encountered a CRM-record, and has therefore 
halted. 



RECORD SELECTION SWITCHES 



These nine switches are operative during the Search-Halt operation, and 
during Selective Output of "edited" magnetic tape. The switches are numbered 
to correspond to the character-positions of the first word of each record on 
the tapee the field which has been edited to contain a record identification, 

Each of these switches may be set to any one of 41 characters, or 
to "ignore" . 

During Search-Halt operation, the Handler searches the magnetic 
tape until it finds a record corresponding to the setting of the 
Record Selection Switches. Then the Handler halts, and the blue 
Handler Search Halt light on the Converter panel is turned on. 

During Selective Output, the Handler performs the same search, 
and then the Converter delivers the selected record to the 
Printer, Paper Tape Punch, or Card Punch. 

If the Converter is set to Single-record operation, the 
operation terminates, and the Converter halts. 

If the Converter is set to Continuous operation, the 
Handler immediately begins another search, and so on. 

During the search, each of the nine Record Selection Switches 
(other than those set to "ignore") is compared with the cor- 
responding character-position in the 80-field of the first word 
in each record on the magnetic tape. The search tenninates when 
exact correspondence is found, in every character-position, 
between the record identification on the tape, and the setting 
of the Record Selection Switches. 



VI - 320 - 6 



NON-DATA CHARACTERS AT THE PRINTER 



When editing programs, or Memory Dumps , for off-line printing, it is not 
possible to rely on the Overflow Alarm to identify those lines which con- 
tain non-data characters. The editing program must test each line, 
before recording it on magnetic tape, to determine whether there are any 
non-data characters in it; if so, then they must be located, and the 
program must edit an additional line as explained on page IV-X-4. All 
of the standard Memory-printout programs include this feature when edit- 
ing for off-line printing. 



CORRECTIONS TO THIS SECTION 



Please make the following corrections in Section VI-320: 

Page 1, add the following just before the heading "Operation Selector" 

All power switches are inoperative whenever the 
Converter is in operation. 



Page 2, Paper Tape to Magnetic Tape; 

The information on paper tape is transcribed as 13-word 
records. 

After a "putaway" code, the rest of the word will be filled 
out with spaces to the right . 

The "compute" code causes a putaway, then fills out the 
balance of the record with spaces . 

Page 2, Magnetic Tape to Paper Tape: 

If the record is shorter than 12 (or 13) words, the Converter 
does not fill out the balance of the 12 -word Punch Block. 
Only the ^ , 10 or 11 words from the Magnetic Tape will be 
punched. 



Page k, Selective Output; 

This Control Switch functions at all times when performing 
an output operation (Print, Punch Cards, Punch Paper Tape) 
from either "edited" or "unedited" magnetic tape. 

NOTE ; All fill-out of the current record is normally with "spaces". 

However, there is a switch inside the Converter cabinet, available 
to maintenance personnel, which will cause all fill-out to be with 
"zeros" instead. 
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PRINTER CONVERTER CONTROL PANEL 



POWER SWITCHES 



At the right side of the panel, in the upper row, are power switches for the 
Converter and Magnetic Tape Handler, and for the Printer. 

Each of these units is represented on the Control panel by: 

An ON button; 
An OFF button; 
A BUSY light. 

When the power is turned on at either unit, its ON button will 
show a blue light (not ready), while that unit goes through its 
own warmup-test cycle. 

When the imit has completed its self-testing operation, its ON 
button will show a yellow light ( ready) . 

Whenever the unit is actually in use, its yellow BUSY light will 
be turned on. 

If the unit should, for any reason, go into an Error-Halt, its 
ON button will show a red light. 



OPERATION SELECTOR 



This dial switch selects the operation which is to be performed by the 
Converter: 

Print "edited" magnetic tape 
Print "unedited" magnetic tape 
Selective Print "edited" magnetic tape 

Search magnetic tape for a record corresponding to the 

Record Selection Switches, then Halt 
Advance magnetic tape one record 
Backup magnetic tape one record 

For this purpose, an "edited" magnetic tape is defined as a tape on which 
every record has had its first word edited to contain a slew control in the 
99-field, and a record identification in the SO-field. 

Operating in the "edited" mode, the Converter delivers to the 
Printer the second through the thirteenth word of every record. 
If the record contains less than 13 words, the Converter fills 
out the balance of the Print Line with "spaces". 
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All the slew controls described on page IV -X -3 are effective, 
except that there is no "branch" marker set by a "skip" code 
on the Printer's slew-control tape loop. Therefore, when 
editing for off-line printing, it is necessary to have the 
editing program count the lines on each page. 

For this purpose, an "unedited" magnetic tape is defined as a tape 
on which the records have not had their first words edited in this 
fashion. 

Operating in the "unedited" mode, the Converter delivers 
the first through the twelfth word of every record to the 
Printer. If the record contains less than 12 words, the 
Converter fills out the balance of the Print Line with 
"spaces". 

Since there is no slew control in the magnetic tape record, 
the positions 0, 1, 2 of this switch govern the vertical 
spacing of the Printer; they cause it to skip 0, 1, or 2 
lines after each printed line (that is, print single, double, 
or triple-space). On the Printer's slew-control tape loop, 
the configurations "skip" and "stop" retain their functions, 
and may be used in their conventional capacities, except for 
automatic end-of-page branch (see page IV'-X-3) . 



OPERATING CONTROLS 



At the left side of the panel, in the second row, are four Operating Control 
Switches: 



OPERATE CONVERTER ; 

Pressing this switch causes the Converter to begin operating as 
defined by the Operation Selector Switch, and by the other 
Operating Control Switches. 



RESET CONVERTER : 

Pressing this switch returns the Converter to the operating 
state after an Error-Halt. The red light in the Converter's 
Power On Switch will then be replaced by a yellow light. 
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CONTINUOUS /SINGLE ; 



GRM: 



Yellow light* Continuous operation. The Converter vdll 
perform the printing operation specified by the Operation 
Selector Svdtch, continuously. 

Blue light: Single-record operation. The Converter vdll 
print the contents of one magnetic tape record (i.e. one line 
of print) and then halt. 



Yellow light: Halt, if the Converter encounters any magnetic 
tape record containing a CRM ("v" in the 44-field of the first 
word). Do not print the CRM-record. 

Blue light: Ignore the presence of a CRM in any record, 
treating it just like any other record. 



STATUS LIGHTS 

At the left side of the panel, in the top row, are four Status Lights: 

HANDLER , OPERATOR ATTENTION : Blue light. 

The Handler is at the end of the tape (positioned on the 
trailer), or else it has finished rewinding (positioned on the 
leader) . 

HANDLER ERROR HALT : Red light. Reset at the Handler. 

HANDLER SEARCH HALT: Blue light. 

When performing the Search-Halt Operation, the Handler has found 
the desired record, and has therefore halted. 

HANDLER CRM HALT : Blue light. 

The Handler has encountered a CRM-record, and has therefore 
halted. 
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RECORD SELECTION SWITCHES 



These nine switches are operative during the Search-Halt operation, and 
during Selective Printing of "edited" magnetic tape. The sid.tches are 
numbered to correspond to the character-positions of the first word of each 
record on the tape: the field which has been edited to contain a record 
identif i cation . 

Each of these switches may be set to any one of 41 characters, 
or to "ignore" . 

During Search-Halt operation, the Handler searches the magnetic 
tape until it finds a record corresponding to the setting of the 
Record Selection Switches. Then the Handler halts, and the blue 
Handler Search Halt light on the Converter panel is turned on. 

During Selective Printing, the Handler performs the same search, 
and then the Converter delivers the selected record to the 
Printer. 

If the Converter is set to Single-record operation, the 
operation terminates, and the Converter halts. 

If the Converter is set to Continuous operation, the 
Handler immediately begins another search, and so on. 

During the search, each of the nine Record Selection Switches 
(other than those set to "ignore") is compared with the corres- 
ponding character-position in the 80-field of the first word in 
each record on the magnetic tape. The search terminates when 
exact correspondence is found, in every character-position, 
between the record identification on the tape, and the setting 
of the Record Selection Switches. 



NON-DATA CHARACTERS AT THE PRINTER 



When editing programs, or Memory Dumps, for off-line printing, it is not 
possible to rely on the Overflow Alarm to identify those lines which contain 
non-data characters. The editing program must test each line, before re- 
cording it on magnetic tape, to determine whether there are any non-data 
characters in it; if so, then they must be located, and the program must 
edit an additional line as explained on page IV-X-4. All of the standard 
Memory-printout programs include this feature when editing for off-line 
printing. 
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MAGNETIC TAPE CONTROLLER - CONTROL PANEL 



OPERATING SWITCHES 



SELECTION ; 

This is a rotaiy s"witch i^ich permits any number to be 
assigned to any Controller. 



OPERATE; 



After any error-halt this button resets the Controller, and 
places it back in the operating state. 

Blue light: When power is turned on in the Controller 
(this is done at the Operator's Console) this button shows 
a blue light while the Controller and its Handlers are in 
their automatic warmup-test cycles. 

Yellow light: When the Controller and all its Handlers have 
completed their cycles, this button shows a Yellow light, 
indicating "ready". 



EMERGENCY OFF: 



Power is normally turned on and off in all peripheral units 
from the main Operator's Console, However, in the event of 
fire or other emergency, each peripheral unit has an 
EMERGENCY OFF button which completely cuts off all circuits 
in the unit. 



A NOTE ON THE COPY-BUFFER 



The Controller contains a small circulating buffer-storage, to accommodate 
the minor differences in speed which must occur between the two Handlers 
during a Copy. In a long Copy, the speed differential may build up beyond 
the capacity of this buffer; if so, the Controller automatically stops both 
tapes, repositions them at the beginning of the record in which the buffer 
overran, and then immediately resumes the Copy with no attention from the 
program, or from the operator. In a long Copy, this condition will occur 
after an average of 25^000 words have been copied; in a short Copy it will 
rarely occur. 

VI - 330 _ 3_ 
332 



INDICATOR LIGHTS 



DUELICATE HANDLERS: 



The Controller will :|jnmediately error-halt if two or more of 
its Handlers have been assigned the same number. 



HALT ON BUFFER OVERRUN: 



There may be occasions when Management will choose to take 
the risk of deferring routine maintenance in favor of emergency, 
or high-priority, processing. It is possible oinder these cir- 
cumstances that two Handlers might eventually get far enough 
apart in speed so that the buffer woiild overrun during the first 
record copied, or during first record after the automatic re- 
sumption of a Copy, making it impossible to proceed. 

In that case the Controller error-halts, and turns on the red 
light for BUFFER OVERRUN. 



SEARCH CONTROL ERRORS 



The Search Control Word, Used by Copy, i's: stored in the 
Controller during the, Copy, in a recirculating register. The 
contents of this register is continuously checked; if any 
parity-failure occurs, the Controller error-halts and turns 
on this red, lighto ■ ' . 



CONTROLLER BUSY: 



Yellow light whenever the Controller is busy. This duplicates 
the corresponding light on , the main Operator's Console. 



HANDLER ERROR BRANCH; 



Blue light whenever - one of the Handlers detects an error of the 
type which causes a program branch. 

This light flashes momentarily if the error occurs in a Read, 
Write, or Write-Copy-Read; it stays on until the next time the 
Controller is used if the error occurs in a Write-Copy. 



HANDLER WRITE LOCKOUT; 



Red light to indicate error-halt whenever the program attempts 
to Write on any Handler which is in the Write Lockout state 
(ie - the tape reel does not have a Writ e-Permissive Ring 
attached to it) . 
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HANDLER WRITE ON TRAILER: 



Red light to indicate error-halt if the program, in spite of 
the Destination-Tape Warning Marker (DWM), attempts to record 
on the trailer which fastens the tape to the reel. 



HANDLER BRM/feRM ERROR; 



Red light to indicate error-halt if a Handler encounters a 
failure in the BRM/ERM alternation check, or does not find 
the record-marker id.thin the time permitted by the Timing 
Check, 

This light is also used to indicate any other condition (such 
as broken tape, loss of vacuum, etc.) which would cause a 
Handler to error-halt. 
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MAGNETIC TAPE HANDLER CONTROL PANEL 



OPERATING SWITCHES 



SELECTION: 



This is a rotary switch which permits any number to be as- 
signed to any Handler. If two Handlers on the same Controller 
are assigned the same number, the Controller immediately 
error-halts , 



POWER ON-OFF; 



The Handler is the only peripheral unit with its own power 
control, so that one or more Handlers may be turned off for 
several hours if current processing does not require them. 

This switch is normally left ON, in which case the Handler 
power goes on and off simultaneously with the ContiToller 
power. 

Blue light: When power is turned on in the Handler, this 
button shows a blue light while the Handler is in its automa- 
tic warmup-test cycle. 

Yellow light: When the Handler has completed this cycle, 
this button shows a yellow light, indicating "ready". 



USE LOCKOUT: 



REWINDING: 



SET shows a blue light, or CLEAR shows a yellow light, at all 
times, to indicate the state of the Handler, 

The buttons may be used to SET or CLEAR Use Lockout manually. 



Shows a blue light when the Handler is executing a Rewind. 

The button may be used to manually initiate a Rewind, but 
this button is inoperative while the Handler is in use. 
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INDICATOR LIGHTS 



WRITE LOCKOUT: 



SET shows a blue light, or FREE shows a yellow light, at all 
times, to indicate the state of the Handler. 



TAPE SELECTED: 



A yellow light is turned on for SOURCE or DESTINATEON when 
the Handler is used. This light then remains on, and shows 
the function last executed by the Handler. A Handler will 
usually be used only as source or as destination for extended 
periods of time, and therefore these lights indicate the func- 
tion of each Handler during the current program. 



TAPE MALFUNCTION: 



Red light to indicate Handler error-halt due to failure of any 
of the numerous automatic checks which are continuously being 
performed. 
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WRITE LOCKOUT 

Write Lockout consists of completely disconnecting the record- 
ing circuits in a Handler. It is established on any Handler by the absence 
of a Write-Perraissive Ring attached to the reel of tape. Since NCR pro- 
vides only one Ring per Handler (and several of those should be carefully 
locked away) it is impossible for the operators to attach Rings to reels 
promiscuously, and if a Ring is accidently left on after a reel has been 
removed from the Handler, there will be no Ring available for the next 
reel. As a further safeguard, the reel will not fit into its plastic 
storage-box if it still has a Ring attached to it. 

If desired. Write Lockout may also be established on any 
Handler which is never to be used as Destination, by means of a switch 
available to the Maintenance Engineer. 
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OPERATION OF MAGNETIC TAPE HANDLER 

The Tape Drive mechanism uses a Supply Reel and a Take-up 
Reel, appropriate capstans to lead the tape by the proper route from one 
Reel to the other, pinch-rollers to drive the tape in either direction, 
and brakes to stop the tape. (For simplicity, the pinch-rollers and 
brakes are not sho-wn on the schematic diagram which appears at the end of 
this section.) At each side of the Handler is a glass -en closed vacuum 
chamber containing a free loop of tape; air is pumped out through ports 
at the upper and lower ends of each chamber, and the tape loops are con- 
tinuously held in approximately the positions shown on the diagram. 

While the Handler is operating, the tape is moved at a con- 
tinuous rate past the Read-¥rite Heads, When the tape is moving forward, 
this causes the left-hand loop to shrink, and the right-hand loop to grow, 
in their respective chambers. These "out of balance" conditions are de- 
tected by devices which are highly sensitive to air-pressure changes in 
the chambers, and which cause the Reels to turn, adjusting the slack in 
the loops. 

Whenever the left-hand loop shrinks, the Supply Reel begins to 
unwind; when the loop has resumed its proper size, the Reel stops turning. 
Whenever the right-hand loop grows, the Take-up Reel begins to wind; when 
the loop has resumed its proper size, the Reel stops turning. When the 
tape is moving in the reverse direction, the entire operation is reversed. 
Thus each Reel turns intermittently (although to the eye the motion usually 
appears continuous) in order to accommodate itself to the movement of the 
tape. 
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While the Handler is operating, three Tape Sensing Stations 
are activated by the presence or absence of an electrically conductive 
coating on the back of the tape: 

Tape Sensing Station A ; 

Detects beginning of trailer in the forward direction. 
End-of-tape for Source Tape. 
Error-halt for Destination Tape. 

Detects beginning of leader in the reverse directiono 
Termination of Rewind. 

Tape Sensing Station B ; Active only for Destination Tape. 

Detects presence of leader, indicating that Handler is at 
the beginning of tape. When tape is started, the Write Head 
erases the tape until this Station detects end of leader, at 
which time the Write Head begins to record' the information 
on the tape, about 3 feet from the beginning. 

Detects Destination-tape Warning Marker (DWM) which signals 
that end of tape is approaching. 

Tape Sensing Station C: Active only for Source Tape. 

Detects presence of leader, indicating that Handler is at 
the beginning of tape. When tape is started, no reading is 
attempted until this Station detects end of leader. 

The Timing Check (see Chapter II) is then replaced by the 
requirement that the Read Head must find no information on 
the tape before the first ERM. 

Length of Leader: 24 feet. 

Length of Trailer: 12 feet. 

DWM to Trailer: 40 feet. 

Conductive coating on the back of the tape: 

Leader and Trailer, full width of the tape. 

Destination Warning Marker (DWM), half width of the tape. 
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CHANGING TAPES 

The cabinet door^ which provides access to the tape, is auto- 
matically locked at all times by an electrically-operated bolt, except when 
the Handler is in a Use Lockout state. Therefore the operator cannot touch 
the tape unless it has been rewound, with Use Lockout, by the program. 
When a tape is to be rewound, but remain on the Handler for later use, the 
program will rewind without Use Lockout and deny the operator access to 
the tape. In unusual circumstances it may be necessary to provide manual 
access to the tape at a normally unauthorized time; the operator may then 
set Use Lockout manually on the Control Panel and permit the door to be 
opened, but this cannot happen inadvertently. 

When the tape is being rewound, the operation continues until 
the beginning of the leader is detected at Tape Sensing Station "A", 
whereupon the tape comes to rest with the tape-to-leader splice lying be- 
tween "A" and the Supply Reel. If the tape was rewound with Use Lockout, 
the operator may now open the door, and this automatically sets a brake on 
each Reel. 

The operator must next swing the Tape Clamp into position to 

hold the tape against "A" . He then: 

Opens the splice 

Removes the Supply Reel 

Transfers the Write-Permissive Ring to the new 
Supply Reel if this is a Destination Tape 

Mounts the new Supply Reel 

Splices the tape to the leader 

Releases the Tape Clamp 

Closes the door (which releases the Reel Brakes) 

Presses CLEAR USE LOCKOUT on the Control Panel. 

and the Handler is once more ready for use, with the door locked. 

332 ^ 



If the operator forgets to release the Tape Clamp, or fails 
to close the door properly, the CLEAR USE LOCKOUT button is inoperative, 
and the Handler will remain in the Use Lockout state until both conditions 
have been corrected. If a tape should be mounted on a Handler while the 
power is off (the door is unlocked at that time also) and then the power 
turned on, the Handler will never complete its warmup-test cycle (blue 
light in the Power button) unless the Tape Clamp is released and the door 
closed, even if the Handler is not in Use Lockout. 

The tape-to-leader splice is accomplished in the following 
manner: 



MAGNETIC TAPE 



LEADER PERMANENTLY FASTENED 
TO TAKE-UP REEL 




UNFASTENED 




FASTENED 

It will be noted that the leader (which is permanently fastened 
to the Take-up Reel) remains completely threaded at all times while chang- 
ing tapes. In fact, the major portion of the tape drive is hidden by a 
cover, represented by the shaded area in the schematic diagram. This cover 
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seizes as a dust-guard for the Read-Write Heads, and also locks the glass 
doors of the vacuum chambers; the operator shoiild never have any reason 
to open this cover. 

Near each Reel is a button marked REEL BRAKE. While this 
button is pressed, the brake on the corresponding Reel is released. The 
operator will momentarily release the brake on the Supply Reel so that he 
may rotate it to the most convenient position for closing the tape-to- 
leader splice. Only the Maintenance Engineer should ever have occasion to 
touch the release button for the Take-up Reel. 
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MAGNETIC TAPE HANDLER 



332 MAGNETIC TAPE HANDLER 

CONTROL PANEL 



CONTROLLER 



1 



DUPLICATE 
HANDLERS 



CONTROLLER 



BUFFER 
OVERRUN 



CONTROLLER 






SEARCH CONTROL 
ERROR 



CONTROLLER 



1 



BUSY 




OPERATE 




SELECTION 



HANDLER 



ERROR 
HALT 




HANDLER 



WRITE 
LOCKOUT 



HANDLER 



HANDLER 



WRITE ON 
TRAILER 



BRM/ERM 
ERROR 



EMERGENCY 
OFF 
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332 MAGNETIC TAPE HANDLER 

CONTROL PANEL 






USE LOCKOUT 

SET CLEAR 



REWINDING 



WRITE LOCKOUT 

SET FREE 



TAPE SELECTED 

SOURCE DESTINATION 



TAPE 
MALFUNCTION 





POWER 

ON - OFF 



TAPE UNIT SELECTION 
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The follovd.ng list gives the Operation Codes., Operation Names, and 

Standard Abbreviations for all Operations in the National 304 Data Processor. 



1 


Add 


ADD 




s 


2 


Subtract 


SUB 






3 


Multiply 


MULT 








Round 


MULT 


:R 




4 


Divide Rirrht- Justified 


DRJ 








Round 


DRJ 


rR 


T 


5 


Divide Left- Justified 


DLJ 






6 


Modify Add 


MADD 






7 


Modify Subtract 


MSUB 






S 


Extract 


EXT" 






9 


Insert 


SERT 






D 


Add Binary 


BINA 




U 




Modulo 64 


BINA 


!M 


V 


A 


Complement Binary 


BINC 




U 


A 


Test Bit 


TBIT 




V 


B 


Compare Nxjmeric 


CN! 




w 


C 


Compare Alphanumeric 


CA- 


! 




D 


Compare Equality 


CE! 






E 


Count 


CNT- 






F 


Test 




w 




Overflow 


TEST- 


'.& 






Option Switch 


TEST: 


s 






Reader Code 


TEST J 


R 


X 




Punch Code 


TEST: 


P 


Y 


H 


Combine 


COMB: 






J 


Distribute 


DIST: 








Sign Split-off 


DIST: 


S 




K 


Suppress 


SUPP: 








Sign Split-off 


SUPP: 


S 




L 


Edit 


EDIT: 




Z 




Check-Protection 


EDIT: 


P 


Z 


M 


Merge 




-X- 




Cutoff 


MRGE:C 






Runout 


MRGErR 




N 


Move 


MOVE: 




cr 


Pack 


PACK: 




p 


Unpack 


UNPK: 




Q 


Sift 


SIFT: 




R 


Siommarize 


SUMM: 







Rev/ind Magnetic Tape 

Source Tape 

Destination Tape 

Use Lockout, Source 

Use Lockout, Destination 
Read Magnetic Tape 

Complete Records 

Partial Records 

Test Branch Conditions 

Index Forward 

Index Backward 
Write-Copy 
Write-C opy-Read 
Copy 

Copy-Read 
Write Ma.gnetic Tape 

Fixed-Length Records 

Variable -Length Records 

Test Branch Conditions 
Write Tape and Erase to End 

Fixed-Length Records 

Variable-Iaength Records 
Print 
Type-Punch 

Console Typewriter 

(variations thru 5) 

High-Speed Punch 
Fixed Format 
Programmed Format 
Read Paper Tape 
Halt 
Read Cards 



VJIND:S 
IVIND:D 
L(5CK:S 
L(?GK:D 

READ: 
READrP 
READ:T 
INDX:F 
INDX:B 
WC: 
WC:R 
COPY: 
Cd!PY:R 

W:F 
WT:V 
WT:T 

WTE:F 
WTE:V 
PRNT: 

TYPE: 



PPT:F 
PPT:P 
RPT: 
HALT: 
ROD: 
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CONVENTIONS GOVERNING USE OF "SPECIAL" CELLS 
IN NCR 304 PROCESSOR MEMORY 



In a 2000-Word Memory, there vdll be 400 "Special" Cells, outside the Main 
Memory-package, and these will be fully sequential within each group of 
100 addresses. The major portion of this additional Memory capacity will 
ncM be used by STEP (Standard Tape Exit Program), making the full 2000-Word 
Main Memory available to the programmer. 

In order to provide for ease of communication between programmers, and for 
interchangability of programs , the following conventions have been adopted 
for the use of the remaining "Special" Cells . All programmers will be 
expected to conform to these conventions. 

(^00 C-Syllable used by Processor as Sequence-Control Register. 
B-Syllable used by Processor for self-linking. 
A-Sy liable may be used by the programmer to store a programmed link , 

thru Used by Processor to store Automonitor information* 
(*04 

thru "^^ ^® used by the programmer as Temporary Storage 
4Qg for intermediate results of computation. 

^09 This Cell will always be named as the irrelevant address, whenever 
one-half of a DISTRIBUTE or a COMBINE is not used. 



@00 Used by Processor to store supplemental information generated by 
Input and Magnetic Tape operations, MULTIPLY, DIVIEE, SUMMARIZE. 

@01 ■ . 

thru To be used by the programmer as additional Temporary Storage. 

@09 



AOO 

thru "^^ ^® ^®®^ ^y ^^^ programmer as Intermediate Storage of information 
QQ which is to be held from program to program during a continuous run, 







DOO 
QOl 
P02 

D06 

ao7 

DOS 
D09 




Memory Size 
(Numeric) 



Memory Size 
(Address-Type) 






^ 







^■XXXXXXXXX 



R M sp sp V sp 1 











sp 



sp 



sp 



sp 



sp 



sp 



sp 



sp 



sp 



sp 



8 



(1304 J 94) is to be used to set up a full word of »dd..#dd" in 
Temporary Storage, then, with a MOVE to set up 9 more words for the 
"Pre-Sentinel" record at the end of a file. 

(0O4:3O) is used in converting a 4-digit number into an 
Address-Type Number. 

(006:90) is used as the first word of a CRM-Record. Since the 
rest of the Record is irrelevant, it may be written directly from 006, 
as either a Fixed-Length or a Variable-Length Record. 



There are 400 additional "Special" Cells in a 4000-Word Memory, 
and no conventions are planned for their use. They are entirely at the 
disposal of the programmer, subject to the restriction that they are 
sequential only within each group of 100 addresses. They are: 
^00 - ^99 £00 - f 99 dOO - d99 sOO - s99 
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MGNETIC TAPE FILE SENTINELS 

1) Every File (ie- Master File, Transaction List, Output Tape, &c) recorded 
on Magnetic Tape will terminate with a CRM-Record as End-of-File Sentinel, 

2) Every Transaction List will contain at least one diimmy item consisting 

entirely of "xxx xx". Any sorting operation will bring these dummies 

to the end of the list, just before the Sentinel, This dummy item is 
automatically placed into the data by the Sorting Program, so that the 
programmer need merely be aware that it is there, 

3) Every file which is updated by the use of any form of COPY" will also 
contain a "Pre-Sentinel" — a 10-word Record consisting entirely of 
"ddd,.,,.dd", immediately preceding the CRM-Record. Whenever any 
insertions are to be made at the end of the file, the Pre-Sentinel will 
stop the COPY and cause the subsequent READ to branch without execution 
on "Greater-Than" • This may be repeated as often as required, to make 
many insertions, 

Hov^rever, when the dummy item is used as a Search Control, the Pr©*-Sentinei 
will be COPIED over, and the true Sentinel (the CRM-Record) will stop 
the COPY, The READ will then branch after termination, because of CRM, 
and this will indicate that the run is complete. 

Note that, while the Sentinel at the end of the Transaction List will 
terminate the last Gulp of transactions, the CRM Sentinel-Record itself 
will never be read from the Transaction List. Reading the CRM Sentinel- 
Reeord from the File will terminate the run. 



The flow-chart shows, in outline form, the overall program for 
the file-posting operation • Since the output is not immediately pertinent, 
creation of the output is not shown in the flow-chart. Also (needless to 
say) any Record deleted from the Master File must be recorded, in some form, 
elsewhere for permanent record, • 



^^^^<^-^^ /jLii//L^ 
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Clear Index Registers 

READ N Records from Transaction List 

Use (@00:43) to set limiter 
in COUNT »A» 

Plant Search Control 

COPT Master File 

COPY STOPPED ON ^Greater-Thaw" 

READ Master File, 1 Record 

am SENTtrgL-RECORD WAS READ 



"res^ 



Post the transaction to the File Record. 
If deletion, set Switch "X" . ^ 

COUNT the Transaction data-stream»; 

READ N Records from Transaction List 

Use (@00:43) to set liniiter 
in COUNT "A" 

Does the next transaction apply to 
this File Record? 



DELETION 



Plant Search Control. 
Svd.tch (Self-resetting) . 
WRITS-COPT Master File. 



Create the new Record 




To 

next 

program 



WRITE a CRM Record 

on each Destination Tape, 



Q REWIND all Tapes. 



PAPER TAPE INPUT-OUTPUT 



NCR TYPEWRITER CODE 

(Odd-Parity) 



TYPEWRITER KEY 


LOWER 
SHIFT 


UPPER 
SHIFT 





) 


1 


1 


2 


£ 


3 


# 


4 


$ 


5 


% 


6 


/ 


7 


& 


8 


* 


9 


( 


A 


^ © 


B 


B 


C 


° ® 


D 


d 


E 


E 


F 


F 


G 


G 


H 


H 


1 


1 


J 


J 


K 


K 


L 


L 


M 


m 


N 


n 


o- 


& 


P 


P 



CHANNELS 



8 




6 


5 


4 




3 


2 


1 










• 






• 




















• 
















• 


















• 


• 














• 


















• 




• 














• 


• 
















• 


• 


• 










• 


• 
















• 








• 


















• 
















• 


















• 


• 














• 


















• 




• 














• 


• 
















• 


• 


• 










• 


















• 








• 


















• 
















• 


















• 


• 














• 


















• 




• 














• 


• 
















• 


• 


• 



TYPEWRITER KEY 


LOWER 
SHIFT 


UPPER 
SHIFT 


Q 


Q 


R 


R 


S 


s 


T 


T 


u 


u 


V 


V 


W 


w 


X 


X 


Y 


Y 


Z 


Z 


@ 


+ 


^ 


n 


- 


A 


• 


♦ 


SPACE 


SPACE 


PUTAWAY 


PUTAWAY 
J^ © 


COMPUTE 
> ® 


STOP 

3 © 


CLEAR 

!S ® 


CLEAR 

m © 


UP 
SHIFT © 


UP 
SHIFT © 


DOWN 
SHIFT ® 


DOWN 
SHIFT © 


CODE 
DELETE © 


CODE 
DELETE © 


TAPE 
FEED © 


TAPE 
FEED © 


-CARR _ 
© RET ® 


© RET ® 


© TAB © 


© TAB ® 


BACKSPACE 

® 



CHANNELS 



8 






5 


4 




3 


2 


1 










• 


















• 








• 
















• 


















• 


• 














• 


















• 




• 














• 


• 
















• 


• 


• 










• 


















• 








• 




























































. 








• 


• 
















• 


















• 




• 






• 








• 




• 














• 


• 


• 








• 








• 


• 








• 








• 








• 


• 






• 


• 


• 


























4» 






• 


• 


• 




• 




• 






• 


• 




DOES NOT PUNCH 
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NOTES 

Q) Input Controls. These exercise control 
functions during input, and store no 
information in memory. 

(2) Typewriter controls. These have no 
function during input, and are ignored. 

(3) When punching with Programmed Formal 
from Processor or Converter 

w (code 11 1110) becomes TAB 

X (code n nil) becomes CARR RET 



n 
o 
O 



PUNCHED CARP COPE 

INPUT-OUTPUT 



1234567 89ABCDEFGHIJ KLMNffP QRST U VWXYZ & • n-$ * / '%#@S+A9i£ ( )dsmne p u \rwx 

X XXXXXXXX X 

lllllllll III III I I 

lllllllll III I II 

loo 00 0000 00000000 000 0000000 llllllllQOOOOO IIIOOO loo |0 |||00 00Q|0 

1l1 1 1 1 1 1 1 1l1 1 1 1 1 11 1 11 11 1 1 1 11 1 1 1 1 1 1 1 1 1 11 11 1 11 1 1 1 1 1 11 1 1 1 1 1 11 1 11 11 1 

2 2 1 2 2 2 2 2 2 2 2 1 2 2 2 2 2 2 2 2 1 2 2 2 2 2 2 2 1 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 2 |2 |2 2 2 2 2 

3 3 3 1 3 3 3 3 3 3 3 3 1 3 3 3 3 3 3 3 3 1 3 3 3 3 3 3 3 |3 3 3 3 3 3 3 |3 3 |3 3 |3 |3 3 3 3 3 3 |3 |3 3 3 3 3 3 3 3 3 
4444|44444444|44444444|4444444|4 444444|4 4|4 4|4|4 444 4|4 444 4|4 4 444 
5 5 5 5 5 I 5 5 5 5 5 5 5 5 1 5 5 5 5 5 5 5 5 1 5 5 5 5 5 5 5 1 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 5 |5 ||5 5 5 5 |5 5 5 |5 I 
666666|66666 666|66666666|6666666|6666666666666666666666666666666 
777 7 777 17777 77 77 |77777777|7777777|777777777777 7777 177777 ||7||7|7 
888888 8 8|8888 8888|88888888|8888 888|88||8||8||||88 Ills 18 8 8 8 8 lllll 
999999999|99999999|999999 99|9999999|9 999999 99999999999 19 99999999 



X WILL NOT PRINT ON I.B.M. 026 PRINTING KEY PUNCH 



NOTE: The characters shown above, following "space", can be punched through a modifi- 
cation of the I.B.M. 026 Printing Key Punch, whereby these characters have been assigned 
to the number-shift position on the following keys: 

KEY REQTAFDSGNHZCVWX 
CHARACTER +A^£( ) d smn e p u vwx 

The I.B.M. 523 Summary Punch can also be modified to permit punching these characters 
from the Universal Converter. 



PAPER TAPE INPUT-OUTPUT 



CHARACTERS | 


046-047 


304 








1 


1 


2 


2 


3 


3 


4 


4 


5 


5 


6 


6 


7 


7 


8 


8 


9 


9 


A 


A 


B 


B 


C 


C 


D 


D 


E 


E 


F 


F 


G 


G 


H 


H 


1 


1 


J 


J 


K 


K 


L 


L 


M 


M 


N 


N 


O 


O 


P 


P 


Q 


Q 


R 


R 


S 


S 


T 


T 


U 


U 


V 


V 


W 


w» 



I.B.M. 046-047 S-CHANNEL CODE 

(Odd-Parity) 

CHANNELS 

NCR 
IBM 



8 


7 


6 


5 


4 




3 


2 


1 


EL 


X 





V 


8 




4 


2 


1 






• 














































• 










• 








• 
















• 












• 






• 




• 








• 






• 


• 
















• 


• 












• 
















• 


• 
































• 










• 










• 








• 








* 








• 












• 






• 












• 






• 


• 








, 








• 


• 


, 










• 
















• 


• 
















• 


















• 








• 














• 




• 










• 






• 


















• 


















• 


• 










• 






• 


• 


• 








• 


• 


















• 








. 








• 








• 


















• 










• 






• 


















• 


















• 


• 





CHARACTERS | 


046-047 


304 


X 


X 


Y 


Y 


z 


Z 


. 


• 


» 


1 


SPACE 


SPACE 


- 


- 


& 


& 


@ 


@ 


P.I. 1 


i 


n 


U 


P.I. 2 


A 


P.I. 3 


+ 


% 


% 


P.I. 4 


£ 


$ 


$ 


E.C. 1 


( 


E.C. 2 


) 


/ 


/ 


* 


* 


# 


# 


P.I. 5 


d 


P. 1.6 


s 


S.P. 1 


PUTAWAY 
® 


S.P. 2 


COMPUTE 
® 


P. 1.7 


@ © 


END OF LINE 


® 


ERROR 


® 


SKIP 


@ ® 


TAPE FEED 
CODE DELETE 


@ 


CORRECTION 


® 


Cr 


® 



8 


7 


6 


5 


4 




3 


2 


1 


EL 


X 





V 






4 


2 


1 






• 


• 






• 


• 


• 






• 


• 


• 














• 












• 




• 


• 










• 


• 






• 


• 








• 


• 








. 




. 










• 


















• 


• 


• 


















• 


















• 








• 






• 


• 


• 














• 








* 




• 








• 










• 








• 


















• 


• 




^ 






• 




. 




• 




. 




• 


• 
















• 








• 










• 


• 






• 


• 










• 




• 
























• 






• 


• 




• 


• 












• 




• 




• 










• 




• 


• 


• 








• 






• 


• 






^ 




• 




















• 


• 




















• 












• 


• 






• 


• 








• 






• 


• 


• 








• 


• 








• 








• 


• 




• 




• 








• 





NCR 
IBM 



NOTES 

Mj Input Controls. These exercise control functions during input, and 
store no information in memory. 

(2) These hove no function during input, and are ignored. 

(3) When punching with Programmed Format from Processor or Converter 

w (code 11 1 110) becomes SKIP 
X (code 11 1111) becomes P.I. 7 
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PAPER TAPE INPUT-OUTPUT 



TELEGRAPHIC CODE 

(Non-Parity) 



n 
o 
O 

I 



CHARACTERS 


TELEGRAPH 
LETTER 
SHIFT 


304 


A 


A 


B 


B 


c 


C 


D 


D 


E 


E 


F 


F 


G 


G 


H 


H 


1 


1 


J 


J 


K 


K 


L 


L 


M 


M 


N 


N 


O 


& 


P 


P 



CHARACTERS 


TELEGRAPH 
FIGURE 
SHIFT 


304 


- 


- 


? 


COMPUTE 

® 


: 


+ 

® 


$ 


$ 


3 


3 


i 


PUTAWAY 
® 


& 


& 


£ 


^ ® 


8 


8 


t 


* 

® 


( 


( 


) 


) 


• 


• 


1 


1 


9 


9 









CHANNELS 



5 


4 




3 


2 


1 


1 


2 




3 


4 


5 


• 


• 










• 










• 




• 




• 






• 








# 




• 












• 






• 








• 








• 








• 




• 




• 




• 






• 


• 










• 


• 




• 








• 








• 








• 




• 








• 
















• ~ 




• 




• 




• ' 



NCR 
TEL. 



CHARACTERS 


TELEGRAPH 
LETTER 
SHIFT 


304 


Q 


Q 


R 


R 


S 


S 


T 


T 


U 


U 


V 


V 


w 


w 


X 


X 


Y 


Y 


z 


z 


SPACE 


SPACE 


FIGURE 
SHIFT 


FIGURE 
SHIFT CD 


LEHER 
SHIFT 


LETTER 
SHIFT ® 


TAPE 
FEED 


® 


LINE 
FEED 


@ ® 


CARR 
RET 


® ® 



CHARACTERS 


TELEGRAPH 
FIGURE 
SHIFT 


304 


1 


1 


4 


4 


BELL 


@ ® 


5 


5 


7 


7 


» 


□ ® 


2 


2 


/ 


/ 


6 


6 


tf 


^ ® 


SPACE 


SPACE 


FIGURE 
SHIFT 


FIGURE 
SHIFT © 


LEHER 
SHIFT 


LETTER 
SHIFT © 


TAPE 
FEED 


® 


LINE 
FEED 


® ® 


CARR 
RET 


® ® 



CHANNELS 



5 


4 




3 


2 


1 


1 " 


2 




3 


4 


5 


• 


• 








• 




• 






• 




• 






















• 


• 


• 












• 






• 


• 


• 


• 








• 


• 








• 


• 


• 










• 


• 










-• 














• 


• 






• 


• 


• 


• 






• 


• 
















• 


















• 





NCR 
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NOTES 

M^ Input Controls. These exercise control functions during input, and store no information in memory. 
The character "?" is interpreted as COMPUTE CODE. 
The character "!" is interpreted as PUTAWAY. 

Q^ These have no function during input, and are ignored. 

^3N When punching with Programmed Format from Processor or Converter 
^^ v/ (code 11 1110) becomes LINE FEED 

X (code 11 nil) becomes CARR RET 

ff\ Every charocter in telegraphic code has been assigned a character in 304 code. As a result, the 
304 can communicate with any non-standard keyboard. 



PAPER TAPE INPUT 



CHARACTERS 



+ 



PUTAWAY ® 



COMPUTE © 



TAPE FEED 



KIMBALL 

PUNCHED-TAG CODE 

(Non-Parity) 

CHANNELS 



7 6 5 J[ • 3 2 1_ 

7 • 4 2 J_ 

• • • 

• • • 

• • • 

• • • 

• • • 

• • • 

• • • 

• • • 

• • • • 

• • • • 

• • • • 

• • • • • 

• • • • 

• • • 



NCR 
KIMBALL 



When using NCR 

461-3 Recorder 

(single program, 

fixed diode-board) 

the following codes 

are read out from 

positions: 



S-2 



S-3 



S-9 



S-0 



S-1 



DENNISON 

PUNCHED-TAG CODE 

(Even -Parity) 

CHANNELS 



® 



7 


6 


5 


4 < 


3 


2 


1 






V 


7 • 


4 


2 


1 








• • 


• 










• 








• 






• 






• 














• 


• 






• 




• 














• 




• 










> • 


• 








• 


• « 














• • 






• 








• « 




• 








• 


• « 


> • 




• 






• 


• « 


• • 


• 
























• • 


• • 


• 


• 






• 


• • 




• 


• 






• 




> • 


• 


• 






• 






















• 












• 












>' • 












• 









NCR 
DENNISON 



NOTES 

^n Input Controls. These exercise control functions during input, and store no information in memory. 

^y These have no function during input, and are ignored. 

^n Whenever the parent machine reads a "zero", the character " + " will be punched into the paper 
tape. This will enable the programmer to verify, in every case, that a field of the proper length has 
been read into the Processor. The first Arithmetic operation performed on each field within the 
Processor will, of course, replace every " + " with a "zero". 

^) All of Kimball Code, and Dennison Code down through the letter "A", may be used for 5-channel 
telegraphic transmission from outlying data-origination points to the central Data-Processing Centef. 



VI -CODES -5 



PAPER TAPE INPUT 
CASH-CONTROL CODES 



No n -Parity 

May be punched with 

Kimball Tags 



Even-Parity 

May be punched with 

Dennison Tags 



CHANNELS 



CHANNELS 



CHARACTERS 



+ 



PUTAWAY ® 



COMPUTE ® 



TAPE FEED 



® 
® 
® 



8 


7 


6 


5 


4 




3 


2 


1 










• 




• 






• 
































• 




• 














• 
















• 






• 












• 


















• 


• 












• 










• 








• 


















• 






• 










• 








• 










• 






• 






























• 












• 






• 




















• 




• 


• 




• 












• 


• 




• 








• 






• 




• 








• 




• 


• 




• 








• 




• 












• 


• 











When using NCR 

461-3 Recorder 

(single program, 

fixed diode-board) 

the following codes 

are read out from 

positions: 



S-2 



S-3 



S-9 



S-0 



S-1 



8 


7 


6 


5 


4 




3 


2 


1 










• 




• 






• 






• 


















• 








• 




• 














• 










• 






• 






• 












• 


















• 


• 










• 


• 










• 








• 


















• 






• 




• 






• 


• 




• 












• 


• 




• 


• 






















• 








• 




• 


• 




• 






• 


• 






• 




• 






• 






• 


• 










® 












• 
































• 
















• 














• 











NOTES 

Input Controls. These exercise control functions during input, and store no information in memory. 

These have no function during input, and are ignored. 

Whenever the parent machine reads a "zero", the character "-|-" will be punched into the paper 
tape. This v/ill enable the programmer to verify, irt every case, that a field of the proper length has 
been read into the Processor. The first Arithmetic operation performed on each field v/ithin the 
Processor will, of course, replace every " + " with a "zero". 



Cash-Control Codes are formed by substituting Channel 8 for Channel 1 in conventional codes. 
The Cash-Control Codes will normally be used only for input to the Data-Processing System, and 
should be specified for Cash Registers and for all other recording devices which provide mechani- 
cal control over the integrity of cash entries. 

By using the TEST READER CODE Instruction, the Processor program can guarantee that cash 
transactions are input only in Cash-Control Code. Since the Tape-Punching Typewriter is incapable 
of punching in Channel 8, it cannot be manipulated to punch Cash-Control Code, and it is therefore 
impossible to simulate a cash-transaction paper tape with the Typewriter. 



VI -CODES -6 



PAPER TAPE INPUT 

CR CASH-CONTROL CODE (EXTENDED) 

(Odd-Parity) 



TYPEWRITER KEY 


LOWER 
SHIFT 


UPPER 
SHIFT 





) 


1 


1 


O 


r 


3 


# 


4 


$ 


5 


% 


6 


/ 


7 


& 


8 


* 


9 


( 


A 


a Q) 


B 


B 


C 


^ o 


D 


d 


E 


E 


F 


F 


G 


G 


H 


H 


1 


1 


J 


J 


K 


K 


L 


L 


M 


m 


N 


n 


O' 


& 


P 


P 



CHANNELS 



8 




6 


5 


4 




3 


2 


1 










• 






• 




• 
































• 




• 














• 
















• 






• 












• 


















• 


« 




• 












• 


• 












• 










• 








• 










• 
































• 




• 














• 
















• 






• 












• 


















• 


• 




• 












• 


• 












• 










• 








• 










• 
































• 




• 














• 
















• 






• 












• 


















• 


• 




• 












• 


• 





TYPEWRITER KEY 


LOWER 
SHIFT 


UPPER 
SHIFT 


Q 


Q 


R 


R 


S 


s 


T 


T 


U 


u 


V 


V 


W 


w 


X 


X 


Y 


Y 


Z 


Z 


@ 


+ 


^ 


1 — 1 


- 


A 


• 


» 


SPACE 


SPACE 


PUTAWAY 
^ © 


PUTAWAY 
J^ © 


COMPUTE 
> © 


STOP 
1 ® 


CLEAR 

i8J © 


CLEAR 

^ © 


UP 
SHIFT © 


UP 
SHIFT © 


DOWN 
SHIFT © 


DOWN 
SHIFT © 


CODE 
DELETE © 


CODE 
DELETE © 


TAPE 
FEED © 


TAPE 
FEED © 


CARR 
RET ^ 


CARR 
RET ® 


TAB © 


TAB © 


BACKSPACE 

® 



CHANNELS 



8 






5 


4 




3 


2 


1 










• 










• 








• 
























• 




• 














• 
















• 






• 












• 


















• 


• 




• 












• 


• 












• 










• 








• 














































































• 






















• 


















• 




• 














• 














• 




• 






• 








• 










• 








• 




• 




• 


• 






• 


• 






















• 






• 


^ 




• 


• 






• 




• 




. 


• 


• 




DOES NOT PUNCH 



The complete Extended Code (equivalent to NCR Typewriter 
Code) is mechanized in the 360 Paper-Tape Reader, ofFer- 
ing a wide choice of identification characters when this Code 
is used with a keyboard machine and Paper-Tape Recorder. 



NOTES 

(V) Input Controls. These exercise control 
functions during input, and store no 
information in memory. 

Q2) Typewriter controls. These have no 

function during input, and are ignored. 
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The National Cash Register Company 



Dayton 9, Ohio 




The NCR 304 Data Processing System 



April 16, 195B 



Packed NxMeric Information, and Binary Coded Information, 
used as Search Keys 



Since the character "u", whenever it appears in a Search Control 
Word, functions as an "ignore" character, it must never be used as a 
significant character in a Search Control, and therefore it must never be 
part of the Search Key in a file record. 

Normal numeric information, when packed, will never give rise to 
a "u". While "space" or "comma" in the information might, when packed, 
result in a "u", it is extremely unlikely that they will ever appear as 
significant characters in a numeric stock number or account number. 



However, a good deal of caution is required in using binary coded 
information. For example, when the desired sequence of account numbers 
is different from the Processor's normal alphanumeric sorting sequence, 
it is simple to transform the characters of each account number into 
pseudo-characters (\:ising Test Bit, Add Binary Mod 64^ Complement Binary), 
and to use the transformed account numbers throughout the processing, 
BUT if there exists any possibility that some character will be transformed 
into the pseudo-character "u", the transformed account numbers cannot be 
used as Search Controls (and therefore as Search Keys in the file records) 
without further transformation. 

(The same comments apply to "w" when the Search Key is in the first 
word of the file record, but the first word will rarely be used as a Search 
Key.) 

In many applications, particularly in Life Insurance, it is 
necessary to store the complement of a Date as one part of a split Search 
Control. The Date can be reduced to a 3-character field by binary codings 



CdDE 










o 



Y E A R i. 

Left-Hand 

Digit 



>\. 



Y E A R R 
Right-Hand 
Digit 



MONT 



^K. 



H 



TTT 



The Year is encoded as 2 digits; but in dealing vdth long-term 
contracts, it is necessary that an expiration date of '05 (ie-2005) appear 
as being later than »95 (ie-1995) . Therefore, in constructing the coded 
Date (before complementing), insert a 1-bit for the Century if the date is 
in the 21st century, and a O-bit if it is in the 20th century. 

The two digits of the Year (10 possibilities each), and the Month 
(12 possibilities) can be exwessed in k bits each, and the Day (31 possi- 
bilities) can be expressed in 5 bits. 

However, straight binary coding cannot be used; it is necessary 
to avoid all configurations ^^rhich (after complementing) can combine with 
some other configuration in such a way that the six bits in any character- 
position could construct the character "u". In the table below, all those 
configurations have been eliminated. 



J 


nc 


Xi 


u 


U 


-P 


cri 


03 




0) 


Q) 


o 


!>H 


^ 


r-'^ 






76543210 





1 

2 
3 
4 
5 
6 

7 
8 

9 
10 
11 
12 
13 
14 
15 
16 

17 
18 
19 
20 
21 
22 
23 
24 
25 
26 

27 
28 

29 
30 
31 








4 







;:|:|;|:j:;: 


JAN 


8 








;*'X*M'* 


FEB 


6 


- 


+ 


1 


III 


M A R 


8 


H 


1 


2 


•«*.*"!**'^ 


APR 


@ 


+ 


1 + 


4 


M****'M' 


MAY 


sp 


Q 


2 


5 


w^jij 


J U N 


• 


"'<■ 


2 + 


6 




JUL 


» 


Y 


4 


7 


*S;':v!' 


AUG 


B 


1 


4 + 


8 


Iliil 


SEP 


D 


1 8 


5 
5 + 


9 
@ 


SsS-wjSS^^^ 




M cr V 




6 


^ 




DEC 




6 + 


sp 
& 

• 


!•:•:•:•:§ 




:-i-:::-:::$::::::i:i;i:i::::::S 




;;;;;:*:>;';*;$i';':';":';:;:;:;:x;::;:::x^^^^ 


9 


•i-i-i^l^i^iSSi^jiJSji-iJw^^ 


A 


iii:iiS:iii:iiiiiil^:iiii^^^ 


B 


:i^:iii|:§:-i§:-:^iv^^^^^ 


C 


•••I■I•^'^'^'■^"I•l•';v^^.■•;^■•i•:^■•;•;I;^■v 


D 


^iS'iS'iS^'^'^'w'i'i'i'iS'i'i'i^ 


E 


•:;;•S^'^"!•^'.■%v;^^^•^';v^;v•;W^I•.■^ 


F 


•i-S'i'i'iwi-iS-iiii'i'i'x 


G 


:;;iP:$i$::::::::::!w^^ 


H 


iliiiliiiSiiiiiiiiiP^^^^ 


I 
P 


.■■;';';'';';v;';¥:y:!S:\'';%':>i>;A'Xv:';'X%";%^ 


m 


•i^'i'ivi'iy.'':';';';-!':':'!'^^^ 


n 


•iiiiiiiiiiiiiiiiilii^^^^^^ 


& 




P 



TABL 



- 2 - 



Suppose the actual date to be stored in an 8-character field, 
with Field Desigiators as shown: 



Month 



MO 



Day 



DAY 



Year 



CENT 



YR-L YR-R 



The Coded Date is designated Cet)E, and word #1 (the second word) of the 
table is designated TABL. 




To encode Date? 



SERT: 
CN: 



"0" by "+" 
"20" vs ( CENT) 



SERTs 
MSUBs 
SERTj ® 
MSUBs 
SERTs ® 
MSUBj 
SERTs (D 
MSUBs 
SERTs @ 
BINGs 



1i4.it 

(DAY) 
( TABL sOO) 

(MCO 
( TABL t 21) 

(YR-R) 
( TABL S43) 

(YR-L) 
( TABL ;55) 
(CCfoEs22) 



by 

e 

by 

e 

by 

e 

by 

e 

by 



11+ 11 
<»1" 



"P" 



"1" 

"1" 

"lY" 

"1" 



-> CClbEs22 



-> Ctes22 
-> OORs86 



-> CdDEsOO 
-> OORs86 



-4 CdbEslO 
-» 00Rs86 



-> Cd)Es21 
-¥ OOR886 



4 CdbEs22 
-^ cdDEs22 



- 3 



To decode Date: 






CM s 

o 



DI3T: 
TBIT: 

DIST: 

BIMC : 

EXT: 

SIFT: 



in on 



19' 



"p" 



'20' 



■» CENT 



vs (Cdt)E:22) 



4 CENT 



(CC/dE:20) 



(CdDE:00) by 

(TABL) thru 
Y « 0:00 
L - 1 
AF « TABLe 30 



"p" 



(^08) 



DIST; 

UiAx * 

SIFT: 



DIST: 

EXT: 

SIFT: 



DIST: 

EXT: 

SIFT: 



(<t07:20) — ^ > (^09:90 

(C(!fDE:10) by "7+" 

(TABL) thru {f.08) 

Y » 0:21 

AF » TABL 11 

((f,07:20) -> f.09:90 

(cdDE:21) by "lY" 

(TAHL) thru (^08) 

Y « 0:43 
L = 1 

AF * TABLe 8 

((^07:20) ^ ^09:90 

(CCfDE:22) by "d" 

(TABL) thru (^08) 

Y « 0:55 
L « 1 

AF « TABL® 8 



& ^.09:90 



& 



& 



(^09:90 
CCfDE:20 
<^08:00 
<^07 

DAY 
^08:21 



& 



Mcr 

^08:30 
<^07 



& 



YR-R 
^08:55 
^07 



DIST: (^07:20) 



-> ^09:90 & YR~L 




Herbert L, Gross 
Director of Training 
ELECTRONIC MACHINE SALES 
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USE OF SORTING TABLES FOR THE 304 



The published Sorting Tables enable you to calculate the exact 
time for any sorting job. Times in the table are micro-minutes per item 
sorted; when combined Tape Time and Compute Time have been obtained, 
multiply by the number of items to be sorted, and move the decimal point 
6 places to the left in order to obtain the time in minutes. 

The tables assume that the unsorted information is already 
recorded on magnetic tape, and that the sorted information ends up on 
magnetic tape. The times in the tables include all rewinds. 

For a 2-way tape-merge sort, in 2400-word memory, find the 
table for the item-size desired, and look up in the left-hand column the 
Number of Items to be sorted. Stop at the first entry in this column 
which is greater than, or equal to, the number of items to be sorted. 

Thus, for 30,000 6-word items, the table-entry is 32,76S. This 
indicates unit times ofs 

741.9 Tape Time 
361 oO Compute Time 

1102.9 Mcro-minutes per item in 2400-word Memory. 

Multiply this total unit time by 30,000 items, move the decimal 
point six places to the left, and round the result to obtain 33.1 minutes 
for the total sorting job« 

For 4S00-word Memory, use the next higher figure in the Tape 
Time column. Thus for 30,000 6-word items the time is: 

660 o 5 Tape Time 
361.0 Compute Time 

1021o5 Mi c IX) -minutes per item in 4S00-word Memory. 

For 4-way merge, look up Compute Time in the usual way. Then 
cross out every-other entry in the first column (Number of Items) start- 
ing with the first entry. For 6-woixi items you cross out 12S, 512, 
2048, etc. Now look up the number of items in this new version of the 
first column. For 30,000 6-word items you would stop at 65,536 which is 
now the fifth entry. Therefore, the fifth entry in the second column 
(4160 3) gives Tape Time with 2400-word Memory. As before. Tape Time 
with 4800-word Memory is the entry above that. 

For 8-way merge, cross out the first and second, fourth and 
fifth, seventh and eighth, etc., entry in the first column (in this 
example, cross out 128, 256, 1024, 2048, 8192, etc.), and proceed in the 
same way for Tape Time, Compute Time is always the same. 



To recap, for 30,000 6-word items the times are! 







Tape Time 


Compute Time 


2400-wd 


2-way 


741o9 


361,0 


4S00-wd 


2-wa3r 


660»5 


36l„0 


2400-wd 


4-way 


4l6.o3 


36loO 


48G0-wd 


4-way 


334o9 


36l„0 


2400-wd 


S-way 


253o5 


36loO 


4a00-wd 


^-way 


172 ol 


36loO 



For the new 332-2 High-Performance Tape Handlers, use half of 
the Tape Tiraeo This is conservative, since the new rate is 66,600 
char/sec or 2o22 times as fast, and more than makes up for the fact 
that . acceleration times remain the sameo 




Herbert Lo Gross 

Director, Customer Training 

ELECTHDNIC MACHINE SALES 



